--- /dev/null
+//
+// File: vk_platform.h
+//
+/*
+** Copyright (c) 2014-2017 The Khronos Group 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_PLATFORM_H_
+#define VK_PLATFORM_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif // __cplusplus
+
+/*
+***************************************************************************************************
+* Platform-specific directives and type declarations
+***************************************************************************************************
+*/
+
+/* Platform-specific calling convention macros.
+ *
+ * Platforms should define these so that Vulkan clients call Vulkan commands
+ * with the same calling conventions that the Vulkan implementation expects.
+ *
+ * VKAPI_ATTR - Placed before the return type in function declarations.
+ * Useful for C++11 and GCC/Clang-style function attribute syntax.
+ * VKAPI_CALL - Placed after the return type in function declarations.
+ * Useful for MSVC-style calling convention syntax.
+ * VKAPI_PTR - Placed between the '(' and '*' in function pointer types.
+ *
+ * Function declaration: VKAPI_ATTR void VKAPI_CALL vkCommand(void);
+ * Function pointer type: typedef void (VKAPI_PTR *PFN_vkCommand)(void);
+ */
+#if defined(_WIN32)
+ // On Windows, Vulkan commands use the stdcall convention
+ #define VKAPI_ATTR
+ #define VKAPI_CALL __stdcall
+ #define VKAPI_PTR VKAPI_CALL
+#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH < 7
+ #error "Vulkan isn't supported for the 'armeabi' NDK ABI"
+#elif defined(__ANDROID__) && defined(__ARM_ARCH) && __ARM_ARCH >= 7 && defined(__ARM_32BIT_STATE)
+ // On Android 32-bit ARM targets, Vulkan functions use the "hardfloat"
+ // calling convention, i.e. float parameters are passed in registers. This
+ // is true even if the rest of the application passes floats on the stack,
+ // as it does by default when compiling for the armeabi-v7a NDK ABI.
+ #define VKAPI_ATTR __attribute__((pcs("aapcs-vfp")))
+ #define VKAPI_CALL
+ #define VKAPI_PTR VKAPI_ATTR
+#else
+ // On other platforms, use the default calling convention
+ #define VKAPI_ATTR
+ #define VKAPI_CALL
+ #define VKAPI_PTR
+#endif
+
+#include <stddef.h>
+
+#if !defined(VK_NO_STDINT_H)
+ #if defined(_MSC_VER) && (_MSC_VER < 1600)
+ typedef signed __int8 int8_t;
+ typedef unsigned __int8 uint8_t;
+ typedef signed __int16 int16_t;
+ typedef unsigned __int16 uint16_t;
+ typedef signed __int32 int32_t;
+ typedef unsigned __int32 uint32_t;
+ typedef signed __int64 int64_t;
+ typedef unsigned __int64 uint64_t;
+ #else
+ #include <stdint.h>
+ #endif
+#endif // !defined(VK_NO_STDINT_H)
+
+#ifdef __cplusplus
+} // extern "C"
+#endif // __cplusplus
+
+#endif
--- /dev/null
+#ifndef VULKAN_H_
+#define VULKAN_H_ 1
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+#include "vk_platform.h"
+#include "vulkan_core.h"
+
+#ifdef VK_USE_PLATFORM_ANDROID_KHR
+#include "vulkan_android.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_IOS_MVK
+#include "vulkan_ios.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_MACOS_MVK
+#include "vulkan_macos.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_MIR_KHR
+#include <mir_toolkit/client_types.h>
+#include "vulkan_mir.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_VI_NN
+#include "vulkan_vi.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR
+#include <wayland-client.h>
+#include "vulkan_wayland.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_WIN32_KHR
+#include <windows.h>
+#include "vulkan_win32.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_XCB_KHR
+#include <xcb/xcb.h>
+#include "vulkan_xcb.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_XLIB_KHR
+#include <X11/Xlib.h>
+#include "vulkan_xlib.h"
+#endif
+
+
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
+#include <X11/Xlib.h>
+#include <X11/extensions/Xrandr.h>
+#include "vulkan_xlib_xrandr.h"
+#endif
+
+#endif // VULKAN_H_
--- /dev/null
+// Copyright (c) 2015-2018 The Khronos Group Inc.\r
+// \r
+// Licensed under the Apache License, Version 2.0 (the "License");\r
+// you may not use this file except in compliance with the License.\r
+// You may obtain a copy of the License at\r
+// \r
+// http://www.apache.org/licenses/LICENSE-2.0\r
+// \r
+// Unless required by applicable law or agreed to in writing, software\r
+// distributed under the License is distributed on an "AS IS" BASIS,\r
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
+// See the License for the specific language governing permissions and\r
+// limitations under the License.\r
+\r
+// This header is generated from the Khronos Vulkan XML API Registry.\r
+\r
+#ifndef VULKAN_HPP\r
+#define VULKAN_HPP\r
+\r
+#include <algorithm>\r
+#include <array>\r
+#include <cstddef>\r
+#include <cstdint>\r
+#include <cstring>\r
+#include <initializer_list>\r
+#include <string>\r
+#include <system_error>\r
+#include <tuple>\r
+#include <type_traits>\r
+#include <vulkan/vulkan.h>\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+# include <memory>\r
+# include <vector>\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#if !defined(VULKAN_HPP_ASSERT)\r
+# include <cassert>\r
+# define VULKAN_HPP_ASSERT assert\r
+#endif\r
+static_assert( VK_HEADER_VERSION == 74 , "Wrong VK_HEADER_VERSION!" );\r
+\r
+// 32-bit vulkan is not typesafe for handles, so don't allow copy constructors on this platform by default.\r
+// To enable this feature on 32-bit platforms please define VULKAN_HPP_TYPESAFE_CONVERSION\r
+#if defined(__LP64__) || defined(_WIN64) || (defined(__x86_64__) && !defined(__ILP32__) ) || defined(_M_X64) || defined(__ia64) || defined (_M_IA64) || defined(__aarch64__) || defined(__powerpc64__)\r
+# if !defined( VULKAN_HPP_TYPESAFE_CONVERSION )\r
+# define VULKAN_HPP_TYPESAFE_CONVERSION\r
+# endif\r
+#endif\r
+\r
+#if !defined(VULKAN_HPP_HAS_UNRESTRICTED_UNIONS)\r
+# if defined(__clang__)\r
+# if __has_feature(cxx_unrestricted_unions)\r
+# define VULKAN_HPP_HAS_UNRESTRICTED_UNIONS\r
+# endif\r
+# elif defined(__GNUC__)\r
+# define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__)\r
+# if 40600 <= GCC_VERSION\r
+# define VULKAN_HPP_HAS_UNRESTRICTED_UNIONS\r
+# endif\r
+# elif defined(_MSC_VER)\r
+# if 1900 <= _MSC_VER\r
+# define VULKAN_HPP_HAS_UNRESTRICTED_UNIONS\r
+# endif\r
+# endif\r
+#endif\r
+\r
+#if !defined(VULKAN_HPP_INLINE)\r
+# if defined(__clang___)\r
+# if __has_attribute(always_inline)\r
+# define VULKAN_HPP_INLINE __attribute__((always_inline)) __inline__\r
+# else\r
+# define VULKAN_HPP_INLINE inline\r
+# endif\r
+# elif defined(__GNUC__)\r
+# define VULKAN_HPP_INLINE __attribute__((always_inline)) __inline__\r
+# elif defined(_MSC_VER)\r
+# define VULKAN_HPP_INLINE __forceinline\r
+# else\r
+# define VULKAN_HPP_INLINE inline\r
+# endif\r
+#endif\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+# define VULKAN_HPP_TYPESAFE_EXPLICIT\r
+#else\r
+# define VULKAN_HPP_TYPESAFE_EXPLICIT explicit\r
+#endif\r
+\r
+#if defined(_MSC_VER) && (_MSC_VER <= 1800)\r
+# define VULKAN_HPP_CONSTEXPR\r
+#else\r
+# define VULKAN_HPP_CONSTEXPR constexpr\r
+#endif\r
+\r
+\r
+#if !defined(VULKAN_HPP_NAMESPACE)\r
+#define VULKAN_HPP_NAMESPACE vk\r
+#endif\r
+\r
+#define VULKAN_HPP_STRINGIFY2(text) #text\r
+#define VULKAN_HPP_STRINGIFY(text) VULKAN_HPP_STRINGIFY2(text)\r
+#define VULKAN_HPP_NAMESPACE_STRING VULKAN_HPP_STRINGIFY(VULKAN_HPP_NAMESPACE)\r
+\r
+namespace VULKAN_HPP_NAMESPACE\r
+{\r
+\r
+ template <typename FlagBitsType> struct FlagTraits\r
+ {\r
+ enum { allFlags = 0 };\r
+ };\r
+\r
+ template <typename BitType, typename MaskType = VkFlags>\r
+ class Flags\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Flags()\r
+ : m_mask(0)\r
+ {\r
+ }\r
+\r
+ Flags(BitType bit)\r
+ : m_mask(static_cast<MaskType>(bit))\r
+ {\r
+ }\r
+\r
+ Flags(Flags<BitType> const& rhs)\r
+ : m_mask(rhs.m_mask)\r
+ {\r
+ }\r
+\r
+ explicit Flags(MaskType flags)\r
+ : m_mask(flags)\r
+ {\r
+ }\r
+\r
+ Flags<BitType> & operator=(Flags<BitType> const& rhs)\r
+ {\r
+ m_mask = rhs.m_mask;\r
+ return *this;\r
+ }\r
+\r
+ Flags<BitType> & operator|=(Flags<BitType> const& rhs)\r
+ {\r
+ m_mask |= rhs.m_mask;\r
+ return *this;\r
+ }\r
+\r
+ Flags<BitType> & operator&=(Flags<BitType> const& rhs)\r
+ {\r
+ m_mask &= rhs.m_mask;\r
+ return *this;\r
+ }\r
+\r
+ Flags<BitType> & operator^=(Flags<BitType> const& rhs)\r
+ {\r
+ m_mask ^= rhs.m_mask;\r
+ return *this;\r
+ }\r
+\r
+ Flags<BitType> operator|(Flags<BitType> const& rhs) const\r
+ {\r
+ Flags<BitType> result(*this);\r
+ result |= rhs;\r
+ return result;\r
+ }\r
+\r
+ Flags<BitType> operator&(Flags<BitType> const& rhs) const\r
+ {\r
+ Flags<BitType> result(*this);\r
+ result &= rhs;\r
+ return result;\r
+ }\r
+\r
+ Flags<BitType> operator^(Flags<BitType> const& rhs) const\r
+ {\r
+ Flags<BitType> result(*this);\r
+ result ^= rhs;\r
+ return result;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return !m_mask;\r
+ }\r
+\r
+ Flags<BitType> operator~() const\r
+ {\r
+ Flags<BitType> result(*this);\r
+ result.m_mask ^= FlagTraits<BitType>::allFlags;\r
+ return result;\r
+ }\r
+\r
+ bool operator==(Flags<BitType> const& rhs) const\r
+ {\r
+ return m_mask == rhs.m_mask;\r
+ }\r
+\r
+ bool operator!=(Flags<BitType> const& rhs) const\r
+ {\r
+ return m_mask != rhs.m_mask;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return !!m_mask;\r
+ }\r
+\r
+ explicit operator MaskType() const\r
+ {\r
+ return m_mask;\r
+ }\r
+\r
+ private:\r
+ MaskType m_mask;\r
+ };\r
+\r
+ template <typename BitType>\r
+ Flags<BitType> operator|(BitType bit, Flags<BitType> const& flags)\r
+ {\r
+ return flags | bit;\r
+ }\r
+\r
+ template <typename BitType>\r
+ Flags<BitType> operator&(BitType bit, Flags<BitType> const& flags)\r
+ {\r
+ return flags & bit;\r
+ }\r
+\r
+ template <typename BitType>\r
+ Flags<BitType> operator^(BitType bit, Flags<BitType> const& flags)\r
+ {\r
+ return flags ^ bit;\r
+ }\r
+\r
+\r
+ template <typename RefType>\r
+ class Optional\r
+ {\r
+ public:\r
+ Optional(RefType & reference) { m_ptr = &reference; }\r
+ Optional(RefType * ptr) { m_ptr = ptr; }\r
+ Optional(std::nullptr_t) { m_ptr = nullptr; }\r
+\r
+ operator RefType*() const { return m_ptr; }\r
+ RefType const* operator->() const { return m_ptr; }\r
+ explicit operator bool() const { return !!m_ptr; }\r
+\r
+ private:\r
+ RefType *m_ptr;\r
+ };\r
+\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T>\r
+ class ArrayProxy\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR ArrayProxy(std::nullptr_t)\r
+ : m_count(0)\r
+ , m_ptr(nullptr)\r
+ {}\r
+\r
+ ArrayProxy(T & ptr)\r
+ : m_count(1)\r
+ , m_ptr(&ptr)\r
+ {}\r
+\r
+ ArrayProxy(uint32_t count, T * ptr)\r
+ : m_count(count)\r
+ , m_ptr(ptr)\r
+ {}\r
+\r
+ template <size_t N>\r
+ ArrayProxy(std::array<typename std::remove_const<T>::type, N> & data)\r
+ : m_count(N)\r
+ , m_ptr(data.data())\r
+ {}\r
+\r
+ template <size_t N>\r
+ ArrayProxy(std::array<typename std::remove_const<T>::type, N> const& data)\r
+ : m_count(N)\r
+ , m_ptr(data.data())\r
+ {}\r
+\r
+ template <class Allocator = std::allocator<typename std::remove_const<T>::type>>\r
+ ArrayProxy(std::vector<typename std::remove_const<T>::type, Allocator> & data)\r
+ : m_count(static_cast<uint32_t>(data.size()))\r
+ , m_ptr(data.data())\r
+ {}\r
+\r
+ template <class Allocator = std::allocator<typename std::remove_const<T>::type>>\r
+ ArrayProxy(std::vector<typename std::remove_const<T>::type, Allocator> const& data)\r
+ : m_count(static_cast<uint32_t>(data.size()))\r
+ , m_ptr(data.data())\r
+ {}\r
+\r
+ ArrayProxy(std::initializer_list<T> const& data)\r
+ : m_count(static_cast<uint32_t>(data.end() - data.begin()))\r
+ , m_ptr(data.begin())\r
+ {}\r
+\r
+ const T * begin() const\r
+ {\r
+ return m_ptr;\r
+ }\r
+\r
+ const T * end() const\r
+ {\r
+ return m_ptr + m_count;\r
+ }\r
+\r
+ const T & front() const\r
+ {\r
+ VULKAN_HPP_ASSERT(m_count && m_ptr);\r
+ return *m_ptr;\r
+ }\r
+\r
+ const T & back() const\r
+ {\r
+ VULKAN_HPP_ASSERT(m_count && m_ptr);\r
+ return *(m_ptr + m_count - 1);\r
+ }\r
+\r
+ bool empty() const\r
+ {\r
+ return (m_count == 0);\r
+ }\r
+\r
+ uint32_t size() const\r
+ {\r
+ return m_count;\r
+ }\r
+\r
+ T * data() const\r
+ {\r
+ return m_ptr;\r
+ }\r
+\r
+ private:\r
+ uint32_t m_count;\r
+ T * m_ptr;\r
+ };\r
+#endif\r
+\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+\r
+ template <typename Type> class UniqueHandleTraits;\r
+\r
+ template <typename Type>\r
+ class UniqueHandle : public UniqueHandleTraits<Type>::deleter\r
+ {\r
+ private:\r
+ using Deleter = typename UniqueHandleTraits<Type>::deleter;\r
+ public:\r
+ explicit UniqueHandle( Type const& value = Type(), Deleter const& deleter = Deleter() )\r
+ : Deleter( deleter)\r
+ , m_value( value )\r
+ {}\r
+\r
+ UniqueHandle( UniqueHandle const& ) = delete;\r
+\r
+ UniqueHandle( UniqueHandle && other )\r
+ : Deleter( std::move( static_cast<Deleter&>( other ) ) )\r
+ , m_value( other.release() )\r
+ {}\r
+\r
+ ~UniqueHandle()\r
+ {\r
+ if ( m_value ) this->destroy( m_value );\r
+ }\r
+\r
+ UniqueHandle & operator=( UniqueHandle const& ) = delete;\r
+\r
+ UniqueHandle & operator=( UniqueHandle && other )\r
+ {\r
+ reset( other.release() );\r
+ *static_cast<Deleter*>(this) = std::move( static_cast<Deleter&>(other) );\r
+ return *this;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_value.operator bool();\r
+ }\r
+\r
+ Type const* operator->() const\r
+ {\r
+ return &m_value;\r
+ }\r
+\r
+ Type * operator->()\r
+ {\r
+ return &m_value;\r
+ }\r
+\r
+ Type const& operator*() const\r
+ {\r
+ return m_value;\r
+ }\r
+\r
+ Type & operator*()\r
+ {\r
+ return m_value;\r
+ }\r
+\r
+ const Type & get() const\r
+ {\r
+ return m_value;\r
+ }\r
+ \r
+ Type & get()\r
+ {\r
+ return m_value;\r
+ }\r
+\r
+ void reset( Type const& value = Type() )\r
+ {\r
+ if ( m_value != value )\r
+ {\r
+ if ( m_value ) this->destroy( m_value );\r
+ m_value = value;\r
+ }\r
+ }\r
+\r
+ Type release()\r
+ {\r
+ Type value = m_value;\r
+ m_value = nullptr;\r
+ return value;\r
+ }\r
+\r
+ void swap( UniqueHandle<Type> & rhs )\r
+ {\r
+ std::swap(m_value, rhs.m_value);\r
+ std::swap(static_cast<Deleter&>(*this), static_cast<Deleter&>(rhs));\r
+ }\r
+\r
+ private:\r
+ Type m_value;\r
+ };\r
+\r
+ template <typename Type>\r
+ VULKAN_HPP_INLINE void swap( UniqueHandle<Type> & lhs, UniqueHandle<Type> & rhs )\r
+ {\r
+ lhs.swap( rhs );\r
+ }\r
+#endif\r
+\r
+\r
+ template <typename X, typename Y> struct isStructureChainValid { enum { value = false }; };\r
+\r
+ template <class Element>\r
+ class StructureChainElement\r
+ {\r
+ public:\r
+ explicit operator Element&() { return value; }\r
+ explicit operator const Element&() const { return value; }\r
+ private:\r
+ Element value;\r
+ };\r
+\r
+ template<typename ...StructureElements>\r
+ class StructureChain : private StructureChainElement<StructureElements>...\r
+ {\r
+ public:\r
+ StructureChain()\r
+ {\r
+ link<StructureElements...>(); \r
+ }\r
+\r
+ StructureChain(StructureChain const &rhs)\r
+ {\r
+ linkAndCopy<StructureElements...>(rhs);\r
+ }\r
+\r
+ StructureChain& operator=(StructureChain const &rhs)\r
+ {\r
+ linkAndCopy<StructureElements...>(rhs);\r
+ return *this;\r
+ }\r
+\r
+ template<typename ClassType> ClassType& get() { return static_cast<ClassType&>(*this);}\r
+\r
+ private:\r
+ template<typename X>\r
+ void link()\r
+ {\r
+ }\r
+\r
+ template<typename X, typename Y, typename ...Z>\r
+ void link()\r
+ {\r
+ static_assert(isStructureChainValid<X,Y>::value, "The structure chain is not valid!");\r
+ X& x = static_cast<X&>(*this);\r
+ Y& y = static_cast<Y&>(*this);\r
+ x.pNext = &y;\r
+ link<Y, Z...>();\r
+ }\r
+\r
+ template<typename X>\r
+ void linkAndCopy(StructureChain const &rhs)\r
+ {\r
+ static_cast<X&>(*this) = static_cast<X const &>(rhs);\r
+ }\r
+\r
+ template<typename X, typename Y, typename ...Z>\r
+ void linkAndCopy(StructureChain const &rhs)\r
+ {\r
+ static_assert(isStructureChainValid<X,Y>::value, "The structure chain is not valid!");\r
+ X& x = static_cast<X&>(*this);\r
+ Y& y = static_cast<Y&>(*this);\r
+ x = static_cast<X const &>(rhs);\r
+ x.pNext = &y;\r
+ linkAndCopy<Y, Z...>(rhs);\r
+ }\r
+\r
+};\r
+ enum class Result\r
+ {\r
+ eSuccess = VK_SUCCESS,\r
+ eNotReady = VK_NOT_READY,\r
+ eTimeout = VK_TIMEOUT,\r
+ eEventSet = VK_EVENT_SET,\r
+ eEventReset = VK_EVENT_RESET,\r
+ eIncomplete = VK_INCOMPLETE,\r
+ eErrorOutOfHostMemory = VK_ERROR_OUT_OF_HOST_MEMORY,\r
+ eErrorOutOfDeviceMemory = VK_ERROR_OUT_OF_DEVICE_MEMORY,\r
+ eErrorInitializationFailed = VK_ERROR_INITIALIZATION_FAILED,\r
+ eErrorDeviceLost = VK_ERROR_DEVICE_LOST,\r
+ eErrorMemoryMapFailed = VK_ERROR_MEMORY_MAP_FAILED,\r
+ eErrorLayerNotPresent = VK_ERROR_LAYER_NOT_PRESENT,\r
+ eErrorExtensionNotPresent = VK_ERROR_EXTENSION_NOT_PRESENT,\r
+ eErrorFeatureNotPresent = VK_ERROR_FEATURE_NOT_PRESENT,\r
+ eErrorIncompatibleDriver = VK_ERROR_INCOMPATIBLE_DRIVER,\r
+ eErrorTooManyObjects = VK_ERROR_TOO_MANY_OBJECTS,\r
+ eErrorFormatNotSupported = VK_ERROR_FORMAT_NOT_SUPPORTED,\r
+ eErrorFragmentedPool = VK_ERROR_FRAGMENTED_POOL,\r
+ eErrorOutOfPoolMemory = VK_ERROR_OUT_OF_POOL_MEMORY,\r
+ eErrorOutOfPoolMemoryKHR = VK_ERROR_OUT_OF_POOL_MEMORY,\r
+ eErrorInvalidExternalHandle = VK_ERROR_INVALID_EXTERNAL_HANDLE,\r
+ eErrorInvalidExternalHandleKHR = VK_ERROR_INVALID_EXTERNAL_HANDLE,\r
+ eErrorSurfaceLostKHR = VK_ERROR_SURFACE_LOST_KHR,\r
+ eErrorNativeWindowInUseKHR = VK_ERROR_NATIVE_WINDOW_IN_USE_KHR,\r
+ eSuboptimalKHR = VK_SUBOPTIMAL_KHR,\r
+ eErrorOutOfDateKHR = VK_ERROR_OUT_OF_DATE_KHR,\r
+ eErrorIncompatibleDisplayKHR = VK_ERROR_INCOMPATIBLE_DISPLAY_KHR,\r
+ eErrorValidationFailedEXT = VK_ERROR_VALIDATION_FAILED_EXT,\r
+ eErrorInvalidShaderNV = VK_ERROR_INVALID_SHADER_NV,\r
+ eErrorFragmentationEXT = VK_ERROR_FRAGMENTATION_EXT,\r
+ eErrorNotPermittedEXT = VK_ERROR_NOT_PERMITTED_EXT\r
+ };\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(Result value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case Result::eSuccess: return "Success";\r
+ case Result::eNotReady: return "NotReady";\r
+ case Result::eTimeout: return "Timeout";\r
+ case Result::eEventSet: return "EventSet";\r
+ case Result::eEventReset: return "EventReset";\r
+ case Result::eIncomplete: return "Incomplete";\r
+ case Result::eErrorOutOfHostMemory: return "ErrorOutOfHostMemory";\r
+ case Result::eErrorOutOfDeviceMemory: return "ErrorOutOfDeviceMemory";\r
+ case Result::eErrorInitializationFailed: return "ErrorInitializationFailed";\r
+ case Result::eErrorDeviceLost: return "ErrorDeviceLost";\r
+ case Result::eErrorMemoryMapFailed: return "ErrorMemoryMapFailed";\r
+ case Result::eErrorLayerNotPresent: return "ErrorLayerNotPresent";\r
+ case Result::eErrorExtensionNotPresent: return "ErrorExtensionNotPresent";\r
+ case Result::eErrorFeatureNotPresent: return "ErrorFeatureNotPresent";\r
+ case Result::eErrorIncompatibleDriver: return "ErrorIncompatibleDriver";\r
+ case Result::eErrorTooManyObjects: return "ErrorTooManyObjects";\r
+ case Result::eErrorFormatNotSupported: return "ErrorFormatNotSupported";\r
+ case Result::eErrorFragmentedPool: return "ErrorFragmentedPool";\r
+ case Result::eErrorOutOfPoolMemory: return "ErrorOutOfPoolMemory";\r
+ case Result::eErrorInvalidExternalHandle: return "ErrorInvalidExternalHandle";\r
+ case Result::eErrorSurfaceLostKHR: return "ErrorSurfaceLostKHR";\r
+ case Result::eErrorNativeWindowInUseKHR: return "ErrorNativeWindowInUseKHR";\r
+ case Result::eSuboptimalKHR: return "SuboptimalKHR";\r
+ case Result::eErrorOutOfDateKHR: return "ErrorOutOfDateKHR";\r
+ case Result::eErrorIncompatibleDisplayKHR: return "ErrorIncompatibleDisplayKHR";\r
+ case Result::eErrorValidationFailedEXT: return "ErrorValidationFailedEXT";\r
+ case Result::eErrorInvalidShaderNV: return "ErrorInvalidShaderNV";\r
+ case Result::eErrorFragmentationEXT: return "ErrorFragmentationEXT";\r
+ case Result::eErrorNotPermittedEXT: return "ErrorNotPermittedEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+#ifndef VULKAN_HPP_NO_EXCEPTIONS\r
+#if defined(_MSC_VER) && (_MSC_VER == 1800)\r
+# define noexcept _NOEXCEPT\r
+#endif\r
+\r
+ class ErrorCategoryImpl : public std::error_category\r
+ {\r
+ public:\r
+ virtual const char* name() const noexcept override { return VULKAN_HPP_NAMESPACE_STRING"::Result"; }\r
+ virtual std::string message(int ev) const override { return to_string(static_cast<Result>(ev)); }\r
+ };\r
+\r
+#if defined(_MSC_VER) && (_MSC_VER == 1800)\r
+# undef noexcept\r
+#endif\r
+\r
+ VULKAN_HPP_INLINE const std::error_category& errorCategory()\r
+ {\r
+ static ErrorCategoryImpl instance;\r
+ return instance;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::error_code make_error_code(Result e)\r
+ {\r
+ return std::error_code(static_cast<int>(e), errorCategory());\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::error_condition make_error_condition(Result e)\r
+ {\r
+ return std::error_condition(static_cast<int>(e), errorCategory());\r
+ }\r
+\r
+#if defined(_MSC_VER) && (_MSC_VER == 1800)\r
+# define noexcept _NOEXCEPT\r
+#endif\r
+\r
+ class Error\r
+ {\r
+ public:\r
+ virtual ~Error() = default;\r
+\r
+ virtual const char* what() const noexcept = 0;\r
+ };\r
+\r
+ class LogicError : public Error, public std::logic_error\r
+ {\r
+ public:\r
+ explicit LogicError( const std::string& what )\r
+ : Error(), std::logic_error(what) {}\r
+ explicit LogicError( char const * what )\r
+ : Error(), std::logic_error(what) {}\r
+ virtual ~LogicError() = default;\r
+\r
+ virtual const char* what() const noexcept { return std::logic_error::what(); }\r
+ };\r
+\r
+ class SystemError : public Error, public std::system_error\r
+ {\r
+ public:\r
+ SystemError( std::error_code ec )\r
+ : Error(), std::system_error(ec) {}\r
+ SystemError( std::error_code ec, std::string const& what )\r
+ : Error(), std::system_error(ec, what) {}\r
+ SystemError( std::error_code ec, char const * what )\r
+ : Error(), std::system_error(ec, what) {}\r
+ SystemError( int ev, std::error_category const& ecat )\r
+ : Error(), std::system_error(ev, ecat) {}\r
+ SystemError( int ev, std::error_category const& ecat, std::string const& what)\r
+ : Error(), std::system_error(ev, ecat, what) {}\r
+ SystemError( int ev, std::error_category const& ecat, char const * what)\r
+ : Error(), std::system_error(ev, ecat, what) {}\r
+ virtual ~SystemError() = default;\r
+\r
+ virtual const char* what() const noexcept { return std::system_error::what(); }\r
+ };\r
+\r
+#if defined(_MSC_VER) && (_MSC_VER == 1800)\r
+# undef noexcept\r
+#endif\r
+\r
+ class OutOfHostMemoryError : public SystemError\r
+ {\r
+ public:\r
+ OutOfHostMemoryError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfHostMemory ), message ) {}\r
+ OutOfHostMemoryError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfHostMemory ), message ) {}\r
+ };\r
+ class OutOfDeviceMemoryError : public SystemError\r
+ {\r
+ public:\r
+ OutOfDeviceMemoryError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfDeviceMemory ), message ) {}\r
+ OutOfDeviceMemoryError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfDeviceMemory ), message ) {}\r
+ };\r
+ class InitializationFailedError : public SystemError\r
+ {\r
+ public:\r
+ InitializationFailedError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorInitializationFailed ), message ) {}\r
+ InitializationFailedError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorInitializationFailed ), message ) {}\r
+ };\r
+ class DeviceLostError : public SystemError\r
+ {\r
+ public:\r
+ DeviceLostError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorDeviceLost ), message ) {}\r
+ DeviceLostError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorDeviceLost ), message ) {}\r
+ };\r
+ class MemoryMapFailedError : public SystemError\r
+ {\r
+ public:\r
+ MemoryMapFailedError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorMemoryMapFailed ), message ) {}\r
+ MemoryMapFailedError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorMemoryMapFailed ), message ) {}\r
+ };\r
+ class LayerNotPresentError : public SystemError\r
+ {\r
+ public:\r
+ LayerNotPresentError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorLayerNotPresent ), message ) {}\r
+ LayerNotPresentError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorLayerNotPresent ), message ) {}\r
+ };\r
+ class ExtensionNotPresentError : public SystemError\r
+ {\r
+ public:\r
+ ExtensionNotPresentError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorExtensionNotPresent ), message ) {}\r
+ ExtensionNotPresentError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorExtensionNotPresent ), message ) {}\r
+ };\r
+ class FeatureNotPresentError : public SystemError\r
+ {\r
+ public:\r
+ FeatureNotPresentError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorFeatureNotPresent ), message ) {}\r
+ FeatureNotPresentError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorFeatureNotPresent ), message ) {}\r
+ };\r
+ class IncompatibleDriverError : public SystemError\r
+ {\r
+ public:\r
+ IncompatibleDriverError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorIncompatibleDriver ), message ) {}\r
+ IncompatibleDriverError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorIncompatibleDriver ), message ) {}\r
+ };\r
+ class TooManyObjectsError : public SystemError\r
+ {\r
+ public:\r
+ TooManyObjectsError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorTooManyObjects ), message ) {}\r
+ TooManyObjectsError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorTooManyObjects ), message ) {}\r
+ };\r
+ class FormatNotSupportedError : public SystemError\r
+ {\r
+ public:\r
+ FormatNotSupportedError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorFormatNotSupported ), message ) {}\r
+ FormatNotSupportedError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorFormatNotSupported ), message ) {}\r
+ };\r
+ class FragmentedPoolError : public SystemError\r
+ {\r
+ public:\r
+ FragmentedPoolError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorFragmentedPool ), message ) {}\r
+ FragmentedPoolError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorFragmentedPool ), message ) {}\r
+ };\r
+ class OutOfPoolMemoryError : public SystemError\r
+ {\r
+ public:\r
+ OutOfPoolMemoryError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfPoolMemory ), message ) {}\r
+ OutOfPoolMemoryError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfPoolMemory ), message ) {}\r
+ };\r
+ class InvalidExternalHandleError : public SystemError\r
+ {\r
+ public:\r
+ InvalidExternalHandleError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorInvalidExternalHandle ), message ) {}\r
+ InvalidExternalHandleError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorInvalidExternalHandle ), message ) {}\r
+ };\r
+ class SurfaceLostKHRError : public SystemError\r
+ {\r
+ public:\r
+ SurfaceLostKHRError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorSurfaceLostKHR ), message ) {}\r
+ SurfaceLostKHRError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorSurfaceLostKHR ), message ) {}\r
+ };\r
+ class NativeWindowInUseKHRError : public SystemError\r
+ {\r
+ public:\r
+ NativeWindowInUseKHRError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorNativeWindowInUseKHR ), message ) {}\r
+ NativeWindowInUseKHRError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorNativeWindowInUseKHR ), message ) {}\r
+ };\r
+ class OutOfDateKHRError : public SystemError\r
+ {\r
+ public:\r
+ OutOfDateKHRError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfDateKHR ), message ) {}\r
+ OutOfDateKHRError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorOutOfDateKHR ), message ) {}\r
+ };\r
+ class IncompatibleDisplayKHRError : public SystemError\r
+ {\r
+ public:\r
+ IncompatibleDisplayKHRError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorIncompatibleDisplayKHR ), message ) {}\r
+ IncompatibleDisplayKHRError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorIncompatibleDisplayKHR ), message ) {}\r
+ };\r
+ class ValidationFailedEXTError : public SystemError\r
+ {\r
+ public:\r
+ ValidationFailedEXTError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorValidationFailedEXT ), message ) {}\r
+ ValidationFailedEXTError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorValidationFailedEXT ), message ) {}\r
+ };\r
+ class InvalidShaderNVError : public SystemError\r
+ {\r
+ public:\r
+ InvalidShaderNVError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorInvalidShaderNV ), message ) {}\r
+ InvalidShaderNVError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorInvalidShaderNV ), message ) {}\r
+ };\r
+ class FragmentationEXTError : public SystemError\r
+ {\r
+ public:\r
+ FragmentationEXTError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorFragmentationEXT ), message ) {}\r
+ FragmentationEXTError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorFragmentationEXT ), message ) {}\r
+ };\r
+ class NotPermittedEXTError : public SystemError\r
+ {\r
+ public:\r
+ NotPermittedEXTError( std::string const& message )\r
+ : SystemError( make_error_code( Result::eErrorNotPermittedEXT ), message ) {}\r
+ NotPermittedEXTError( char const * message )\r
+ : SystemError( make_error_code( Result::eErrorNotPermittedEXT ), message ) {}\r
+ };\r
+\r
+ VULKAN_HPP_INLINE void throwResultException( Result result, char const * message )\r
+ {\r
+ switch ( result )\r
+ {\r
+ case Result::eErrorOutOfHostMemory: throw OutOfHostMemoryError ( message );\r
+ case Result::eErrorOutOfDeviceMemory: throw OutOfDeviceMemoryError ( message );\r
+ case Result::eErrorInitializationFailed: throw InitializationFailedError ( message );\r
+ case Result::eErrorDeviceLost: throw DeviceLostError ( message );\r
+ case Result::eErrorMemoryMapFailed: throw MemoryMapFailedError ( message );\r
+ case Result::eErrorLayerNotPresent: throw LayerNotPresentError ( message );\r
+ case Result::eErrorExtensionNotPresent: throw ExtensionNotPresentError ( message );\r
+ case Result::eErrorFeatureNotPresent: throw FeatureNotPresentError ( message );\r
+ case Result::eErrorIncompatibleDriver: throw IncompatibleDriverError ( message );\r
+ case Result::eErrorTooManyObjects: throw TooManyObjectsError ( message );\r
+ case Result::eErrorFormatNotSupported: throw FormatNotSupportedError ( message );\r
+ case Result::eErrorFragmentedPool: throw FragmentedPoolError ( message );\r
+ case Result::eErrorOutOfPoolMemory: throw OutOfPoolMemoryError ( message );\r
+ case Result::eErrorInvalidExternalHandle: throw InvalidExternalHandleError ( message );\r
+ case Result::eErrorSurfaceLostKHR: throw SurfaceLostKHRError ( message );\r
+ case Result::eErrorNativeWindowInUseKHR: throw NativeWindowInUseKHRError ( message );\r
+ case Result::eErrorOutOfDateKHR: throw OutOfDateKHRError ( message );\r
+ case Result::eErrorIncompatibleDisplayKHR: throw IncompatibleDisplayKHRError ( message );\r
+ case Result::eErrorValidationFailedEXT: throw ValidationFailedEXTError ( message );\r
+ case Result::eErrorInvalidShaderNV: throw InvalidShaderNVError ( message );\r
+ case Result::eErrorFragmentationEXT: throw FragmentationEXTError ( message );\r
+ case Result::eErrorNotPermittedEXT: throw NotPermittedEXTError ( message );\r
+ default: throw SystemError( make_error_code( result ) );\r
+ }\r
+ }\r
+#endif\r
+} // namespace VULKAN_HPP_NAMESPACE\r
+\r
+namespace std\r
+{\r
+ template <>\r
+ struct is_error_code_enum<VULKAN_HPP_NAMESPACE::Result> : public true_type\r
+ {};\r
+}\r
+\r
+namespace VULKAN_HPP_NAMESPACE\r
+{\r
+\r
+ template <typename T>\r
+ struct ResultValue\r
+ {\r
+ ResultValue( Result r, T & v )\r
+ : result( r )\r
+ , value( v )\r
+ {}\r
+\r
+ ResultValue( Result r, T && v )\r
+ : result( r )\r
+ , value( std::move( v ) )\r
+ {}\r
+\r
+ Result result;\r
+ T value;\r
+\r
+ operator std::tuple<Result&, T&>() { return std::tuple<Result&, T&>(result, value); }\r
+ };\r
+\r
+ template <typename T>\r
+ struct ResultValueType\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ typedef ResultValue<T> type;\r
+#else\r
+ typedef T type;\r
+#endif\r
+ };\r
+\r
+ template <>\r
+ struct ResultValueType<void>\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ typedef Result type;\r
+#else\r
+ typedef void type;\r
+#endif\r
+ };\r
+\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type createResultValue( Result result, char const * message )\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( result == Result::eSuccess );\r
+ return result;\r
+#else\r
+ if ( result != Result::eSuccess )\r
+ {\r
+ throwResultException( result, message );\r
+ }\r
+#endif\r
+ }\r
+\r
+ template <typename T>\r
+ VULKAN_HPP_INLINE typename ResultValueType<T>::type createResultValue( Result result, T & data, char const * message )\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( result == Result::eSuccess );\r
+ return ResultValue<T>( result, data );\r
+#else\r
+ if ( result != Result::eSuccess )\r
+ {\r
+ throwResultException( result, message );\r
+ }\r
+ return std::move( data );\r
+#endif\r
+ }\r
+\r
+ VULKAN_HPP_INLINE Result createResultValue( Result result, char const * message, std::initializer_list<Result> successCodes )\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( std::find( successCodes.begin(), successCodes.end(), result ) != successCodes.end() );\r
+#else\r
+ if ( std::find( successCodes.begin(), successCodes.end(), result ) == successCodes.end() )\r
+ {\r
+ throwResultException( result, message );\r
+ }\r
+#endif\r
+ return result;\r
+ }\r
+\r
+ template <typename T>\r
+ VULKAN_HPP_INLINE ResultValue<T> createResultValue( Result result, T & data, char const * message, std::initializer_list<Result> successCodes )\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( std::find( successCodes.begin(), successCodes.end(), result ) != successCodes.end() );\r
+#else\r
+ if ( std::find( successCodes.begin(), successCodes.end(), result ) == successCodes.end() )\r
+ {\r
+ throwResultException( result, message );\r
+ }\r
+#endif\r
+ return ResultValue<T>( result, data );\r
+ }\r
+\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename T>\r
+ VULKAN_HPP_INLINE typename ResultValueType<UniqueHandle<T>>::type createResultValue( Result result, T & data, char const * message, typename UniqueHandleTraits<T>::deleter const& deleter )\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( result == Result::eSuccess );\r
+ return ResultValue<UniqueHandle<T>>( result, UniqueHandle<T>(data, deleter) );\r
+#else\r
+ if ( result != Result::eSuccess )\r
+ {\r
+ throwResultException( result, message );\r
+ }\r
+ return UniqueHandle<T>(data, deleter);\r
+#endif\r
+ }\r
+#endif\r
+\r
+\r
+ struct AllocationCallbacks;\r
+\r
+ template <typename OwnerType>\r
+ class ObjectDestroy\r
+ {\r
+ public:\r
+ ObjectDestroy(OwnerType owner = OwnerType(), Optional<const AllocationCallbacks> allocator = nullptr)\r
+ : m_owner(owner)\r
+ , m_allocator(allocator)\r
+ {}\r
+\r
+ OwnerType getOwner() const { return m_owner; }\r
+ Optional<const AllocationCallbacks> getAllocator() const { return m_allocator; }\r
+\r
+ protected:\r
+ template <typename T>\r
+ void destroy(T t)\r
+ {\r
+ m_owner.destroy(t, m_allocator);\r
+ }\r
+\r
+ private:\r
+ OwnerType m_owner;\r
+ Optional<const AllocationCallbacks> m_allocator;\r
+ };\r
+\r
+ class NoParent;\r
+\r
+ template <>\r
+ class ObjectDestroy<NoParent>\r
+ {\r
+ public:\r
+ ObjectDestroy( Optional<const AllocationCallbacks> allocator = nullptr )\r
+ : m_allocator( allocator )\r
+ {}\r
+\r
+ Optional<const AllocationCallbacks> getAllocator() const { return m_allocator; }\r
+\r
+ protected:\r
+ template <typename T>\r
+ void destroy(T t)\r
+ {\r
+ t.destroy( m_allocator );\r
+ }\r
+\r
+ private:\r
+ Optional<const AllocationCallbacks> m_allocator;\r
+ };\r
+\r
+ template <typename OwnerType>\r
+ class ObjectFree\r
+ {\r
+ public:\r
+ ObjectFree(OwnerType owner = OwnerType(), Optional<const AllocationCallbacks> allocator = nullptr)\r
+ : m_owner(owner)\r
+ , m_allocator(allocator)\r
+ {}\r
+\r
+ OwnerType getOwner() const { return m_owner; }\r
+ Optional<const AllocationCallbacks> getAllocator() const { return m_allocator; }\r
+\r
+ protected:\r
+ template <typename T>\r
+ void destroy(T t)\r
+ {\r
+ m_owner.free(t, m_allocator);\r
+ }\r
+\r
+ private:\r
+ OwnerType m_owner;\r
+ Optional<const AllocationCallbacks> m_allocator;\r
+ };\r
+\r
+ template <typename OwnerType, typename PoolType>\r
+ class PoolFree\r
+ {\r
+ public:\r
+ PoolFree(OwnerType owner = OwnerType(), PoolType pool = PoolType())\r
+ : m_owner(owner)\r
+ , m_pool(pool)\r
+ {}\r
+\r
+ OwnerType getOwner() const { return m_owner; }\r
+ PoolType getPool() const { return m_pool; }\r
+\r
+ protected:\r
+ template <typename T>\r
+ void destroy(T t)\r
+ {\r
+ m_owner.free(m_pool, t);\r
+ }\r
+\r
+ private:\r
+ OwnerType m_owner;\r
+ PoolType m_pool;\r
+ };\r
+\r
+class DispatchLoaderStatic\r
+{\r
+public:\r
+ VkResult vkAcquireNextImage2KHR( VkDevice device, const VkAcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex ) const\r
+ {\r
+ return ::vkAcquireNextImage2KHR( device, pAcquireInfo, pImageIndex);\r
+ }\r
+ VkResult vkAcquireNextImageKHR( VkDevice device, VkSwapchainKHR swapchain, uint64_t timeout, VkSemaphore semaphore, VkFence fence, uint32_t* pImageIndex ) const\r
+ {\r
+ return ::vkAcquireNextImageKHR( device, swapchain, timeout, semaphore, fence, pImageIndex);\r
+ }\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ VkResult vkAcquireXlibDisplayEXT( VkPhysicalDevice physicalDevice, Display* dpy, VkDisplayKHR display ) const\r
+ {\r
+ return ::vkAcquireXlibDisplayEXT( physicalDevice, dpy, display);\r
+ }\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+ VkResult vkAllocateCommandBuffers( VkDevice device, const VkCommandBufferAllocateInfo* pAllocateInfo, VkCommandBuffer* pCommandBuffers ) const\r
+ {\r
+ return ::vkAllocateCommandBuffers( device, pAllocateInfo, pCommandBuffers);\r
+ }\r
+ VkResult vkAllocateDescriptorSets( VkDevice device, const VkDescriptorSetAllocateInfo* pAllocateInfo, VkDescriptorSet* pDescriptorSets ) const\r
+ {\r
+ return ::vkAllocateDescriptorSets( device, pAllocateInfo, pDescriptorSets);\r
+ }\r
+ VkResult vkAllocateMemory( VkDevice device, const VkMemoryAllocateInfo* pAllocateInfo, const VkAllocationCallbacks* pAllocator, VkDeviceMemory* pMemory ) const\r
+ {\r
+ return ::vkAllocateMemory( device, pAllocateInfo, pAllocator, pMemory);\r
+ }\r
+ VkResult vkBeginCommandBuffer( VkCommandBuffer commandBuffer, const VkCommandBufferBeginInfo* pBeginInfo ) const\r
+ {\r
+ return ::vkBeginCommandBuffer( commandBuffer, pBeginInfo);\r
+ }\r
+ VkResult vkBindBufferMemory( VkDevice device, VkBuffer buffer, VkDeviceMemory memory, VkDeviceSize memoryOffset ) const\r
+ {\r
+ return ::vkBindBufferMemory( device, buffer, memory, memoryOffset);\r
+ }\r
+ VkResult vkBindBufferMemory2( VkDevice device, uint32_t bindInfoCount, const VkBindBufferMemoryInfo* pBindInfos ) const\r
+ {\r
+ return ::vkBindBufferMemory2( device, bindInfoCount, pBindInfos);\r
+ }\r
+ VkResult vkBindBufferMemory2KHR( VkDevice device, uint32_t bindInfoCount, const VkBindBufferMemoryInfo* pBindInfos ) const\r
+ {\r
+ return ::vkBindBufferMemory2KHR( device, bindInfoCount, pBindInfos);\r
+ }\r
+ VkResult vkBindImageMemory( VkDevice device, VkImage image, VkDeviceMemory memory, VkDeviceSize memoryOffset ) const\r
+ {\r
+ return ::vkBindImageMemory( device, image, memory, memoryOffset);\r
+ }\r
+ VkResult vkBindImageMemory2( VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos ) const\r
+ {\r
+ return ::vkBindImageMemory2( device, bindInfoCount, pBindInfos);\r
+ }\r
+ VkResult vkBindImageMemory2KHR( VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos ) const\r
+ {\r
+ return ::vkBindImageMemory2KHR( device, bindInfoCount, pBindInfos);\r
+ }\r
+ void vkCmdBeginDebugUtilsLabelEXT( VkCommandBuffer commandBuffer, const VkDebugUtilsLabelEXT* pLabelInfo ) const\r
+ {\r
+ return ::vkCmdBeginDebugUtilsLabelEXT( commandBuffer, pLabelInfo);\r
+ }\r
+ void vkCmdBeginQuery( VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query, VkQueryControlFlags flags ) const\r
+ {\r
+ return ::vkCmdBeginQuery( commandBuffer, queryPool, query, flags);\r
+ }\r
+ void vkCmdBeginRenderPass( VkCommandBuffer commandBuffer, const VkRenderPassBeginInfo* pRenderPassBegin, VkSubpassContents contents ) const\r
+ {\r
+ return ::vkCmdBeginRenderPass( commandBuffer, pRenderPassBegin, contents);\r
+ }\r
+ void vkCmdBindDescriptorSets( VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t firstSet, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets, uint32_t dynamicOffsetCount, const uint32_t* pDynamicOffsets ) const\r
+ {\r
+ return ::vkCmdBindDescriptorSets( commandBuffer, pipelineBindPoint, layout, firstSet, descriptorSetCount, pDescriptorSets, dynamicOffsetCount, pDynamicOffsets);\r
+ }\r
+ void vkCmdBindIndexBuffer( VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkIndexType indexType ) const\r
+ {\r
+ return ::vkCmdBindIndexBuffer( commandBuffer, buffer, offset, indexType);\r
+ }\r
+ void vkCmdBindPipeline( VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipeline pipeline ) const\r
+ {\r
+ return ::vkCmdBindPipeline( commandBuffer, pipelineBindPoint, pipeline);\r
+ }\r
+ void vkCmdBindVertexBuffers( VkCommandBuffer commandBuffer, uint32_t firstBinding, uint32_t bindingCount, const VkBuffer* pBuffers, const VkDeviceSize* pOffsets ) const\r
+ {\r
+ return ::vkCmdBindVertexBuffers( commandBuffer, firstBinding, bindingCount, pBuffers, pOffsets);\r
+ }\r
+ void vkCmdBlitImage( VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageBlit* pRegions, VkFilter filter ) const\r
+ {\r
+ return ::vkCmdBlitImage( commandBuffer, srcImage, srcImageLayout, dstImage, dstImageLayout, regionCount, pRegions, filter);\r
+ }\r
+ void vkCmdClearAttachments( VkCommandBuffer commandBuffer, uint32_t attachmentCount, const VkClearAttachment* pAttachments, uint32_t rectCount, const VkClearRect* pRects ) const\r
+ {\r
+ return ::vkCmdClearAttachments( commandBuffer, attachmentCount, pAttachments, rectCount, pRects);\r
+ }\r
+ void vkCmdClearColorImage( VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearColorValue* pColor, uint32_t rangeCount, const VkImageSubresourceRange* pRanges ) const\r
+ {\r
+ return ::vkCmdClearColorImage( commandBuffer, image, imageLayout, pColor, rangeCount, pRanges);\r
+ }\r
+ void vkCmdClearDepthStencilImage( VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearDepthStencilValue* pDepthStencil, uint32_t rangeCount, const VkImageSubresourceRange* pRanges ) const\r
+ {\r
+ return ::vkCmdClearDepthStencilImage( commandBuffer, image, imageLayout, pDepthStencil, rangeCount, pRanges);\r
+ }\r
+ void vkCmdCopyBuffer( VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferCopy* pRegions ) const\r
+ {\r
+ return ::vkCmdCopyBuffer( commandBuffer, srcBuffer, dstBuffer, regionCount, pRegions);\r
+ }\r
+ void vkCmdCopyBufferToImage( VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkBufferImageCopy* pRegions ) const\r
+ {\r
+ return ::vkCmdCopyBufferToImage( commandBuffer, srcBuffer, dstImage, dstImageLayout, regionCount, pRegions);\r
+ }\r
+ void vkCmdCopyImage( VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageCopy* pRegions ) const\r
+ {\r
+ return ::vkCmdCopyImage( commandBuffer, srcImage, srcImageLayout, dstImage, dstImageLayout, regionCount, pRegions);\r
+ }\r
+ void vkCmdCopyImageToBuffer( VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferImageCopy* pRegions ) const\r
+ {\r
+ return ::vkCmdCopyImageToBuffer( commandBuffer, srcImage, srcImageLayout, dstBuffer, regionCount, pRegions);\r
+ }\r
+ void vkCmdCopyQueryPoolResults( VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize stride, VkQueryResultFlags flags ) const\r
+ {\r
+ return ::vkCmdCopyQueryPoolResults( commandBuffer, queryPool, firstQuery, queryCount, dstBuffer, dstOffset, stride, flags);\r
+ }\r
+ void vkCmdDebugMarkerBeginEXT( VkCommandBuffer commandBuffer, const VkDebugMarkerMarkerInfoEXT* pMarkerInfo ) const\r
+ {\r
+ return ::vkCmdDebugMarkerBeginEXT( commandBuffer, pMarkerInfo);\r
+ }\r
+ void vkCmdDebugMarkerEndEXT( VkCommandBuffer commandBuffer ) const\r
+ {\r
+ return ::vkCmdDebugMarkerEndEXT( commandBuffer);\r
+ }\r
+ void vkCmdDebugMarkerInsertEXT( VkCommandBuffer commandBuffer, const VkDebugMarkerMarkerInfoEXT* pMarkerInfo ) const\r
+ {\r
+ return ::vkCmdDebugMarkerInsertEXT( commandBuffer, pMarkerInfo);\r
+ }\r
+ void vkCmdDispatch( VkCommandBuffer commandBuffer, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ ) const\r
+ {\r
+ return ::vkCmdDispatch( commandBuffer, groupCountX, groupCountY, groupCountZ);\r
+ }\r
+ void vkCmdDispatchBase( VkCommandBuffer commandBuffer, uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ ) const\r
+ {\r
+ return ::vkCmdDispatchBase( commandBuffer, baseGroupX, baseGroupY, baseGroupZ, groupCountX, groupCountY, groupCountZ);\r
+ }\r
+ void vkCmdDispatchBaseKHR( VkCommandBuffer commandBuffer, uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ ) const\r
+ {\r
+ return ::vkCmdDispatchBaseKHR( commandBuffer, baseGroupX, baseGroupY, baseGroupZ, groupCountX, groupCountY, groupCountZ);\r
+ }\r
+ void vkCmdDispatchIndirect( VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset ) const\r
+ {\r
+ return ::vkCmdDispatchIndirect( commandBuffer, buffer, offset);\r
+ }\r
+ void vkCmdDraw( VkCommandBuffer commandBuffer, uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance ) const\r
+ {\r
+ return ::vkCmdDraw( commandBuffer, vertexCount, instanceCount, firstVertex, firstInstance);\r
+ }\r
+ void vkCmdDrawIndexed( VkCommandBuffer commandBuffer, uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance ) const\r
+ {\r
+ return ::vkCmdDrawIndexed( commandBuffer, indexCount, instanceCount, firstIndex, vertexOffset, firstInstance);\r
+ }\r
+ void vkCmdDrawIndexedIndirect( VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride ) const\r
+ {\r
+ return ::vkCmdDrawIndexedIndirect( commandBuffer, buffer, offset, drawCount, stride);\r
+ }\r
+ void vkCmdDrawIndexedIndirectCountAMD( VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride ) const\r
+ {\r
+ return ::vkCmdDrawIndexedIndirectCountAMD( commandBuffer, buffer, offset, countBuffer, countBufferOffset, maxDrawCount, stride);\r
+ }\r
+ void vkCmdDrawIndirect( VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride ) const\r
+ {\r
+ return ::vkCmdDrawIndirect( commandBuffer, buffer, offset, drawCount, stride);\r
+ }\r
+ void vkCmdDrawIndirectCountAMD( VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride ) const\r
+ {\r
+ return ::vkCmdDrawIndirectCountAMD( commandBuffer, buffer, offset, countBuffer, countBufferOffset, maxDrawCount, stride);\r
+ }\r
+ void vkCmdEndDebugUtilsLabelEXT( VkCommandBuffer commandBuffer ) const\r
+ {\r
+ return ::vkCmdEndDebugUtilsLabelEXT( commandBuffer);\r
+ }\r
+ void vkCmdEndQuery( VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query ) const\r
+ {\r
+ return ::vkCmdEndQuery( commandBuffer, queryPool, query);\r
+ }\r
+ void vkCmdEndRenderPass( VkCommandBuffer commandBuffer ) const\r
+ {\r
+ return ::vkCmdEndRenderPass( commandBuffer);\r
+ }\r
+ void vkCmdExecuteCommands( VkCommandBuffer commandBuffer, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers ) const\r
+ {\r
+ return ::vkCmdExecuteCommands( commandBuffer, commandBufferCount, pCommandBuffers);\r
+ }\r
+ void vkCmdFillBuffer( VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize size, uint32_t data ) const\r
+ {\r
+ return ::vkCmdFillBuffer( commandBuffer, dstBuffer, dstOffset, size, data);\r
+ }\r
+ void vkCmdInsertDebugUtilsLabelEXT( VkCommandBuffer commandBuffer, const VkDebugUtilsLabelEXT* pLabelInfo ) const\r
+ {\r
+ return ::vkCmdInsertDebugUtilsLabelEXT( commandBuffer, pLabelInfo);\r
+ }\r
+ void vkCmdNextSubpass( VkCommandBuffer commandBuffer, VkSubpassContents contents ) const\r
+ {\r
+ return ::vkCmdNextSubpass( commandBuffer, contents);\r
+ }\r
+ void vkCmdPipelineBarrier( VkCommandBuffer commandBuffer, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, VkDependencyFlags dependencyFlags, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers ) const\r
+ {\r
+ return ::vkCmdPipelineBarrier( commandBuffer, srcStageMask, dstStageMask, dependencyFlags, memoryBarrierCount, pMemoryBarriers, bufferMemoryBarrierCount, pBufferMemoryBarriers, imageMemoryBarrierCount, pImageMemoryBarriers);\r
+ }\r
+ void vkCmdProcessCommandsNVX( VkCommandBuffer commandBuffer, const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo ) const\r
+ {\r
+ return ::vkCmdProcessCommandsNVX( commandBuffer, pProcessCommandsInfo);\r
+ }\r
+ void vkCmdPushConstants( VkCommandBuffer commandBuffer, VkPipelineLayout layout, VkShaderStageFlags stageFlags, uint32_t offset, uint32_t size, const void* pValues ) const\r
+ {\r
+ return ::vkCmdPushConstants( commandBuffer, layout, stageFlags, offset, size, pValues);\r
+ }\r
+ void vkCmdPushDescriptorSetKHR( VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t set, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites ) const\r
+ {\r
+ return ::vkCmdPushDescriptorSetKHR( commandBuffer, pipelineBindPoint, layout, set, descriptorWriteCount, pDescriptorWrites);\r
+ }\r
+ void vkCmdPushDescriptorSetWithTemplateKHR( VkCommandBuffer commandBuffer, VkDescriptorUpdateTemplate descriptorUpdateTemplate, VkPipelineLayout layout, uint32_t set, const void* pData ) const\r
+ {\r
+ return ::vkCmdPushDescriptorSetWithTemplateKHR( commandBuffer, descriptorUpdateTemplate, layout, set, pData);\r
+ }\r
+ void vkCmdReserveSpaceForCommandsNVX( VkCommandBuffer commandBuffer, const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo ) const\r
+ {\r
+ return ::vkCmdReserveSpaceForCommandsNVX( commandBuffer, pReserveSpaceInfo);\r
+ }\r
+ void vkCmdResetEvent( VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask ) const\r
+ {\r
+ return ::vkCmdResetEvent( commandBuffer, event, stageMask);\r
+ }\r
+ void vkCmdResetQueryPool( VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount ) const\r
+ {\r
+ return ::vkCmdResetQueryPool( commandBuffer, queryPool, firstQuery, queryCount);\r
+ }\r
+ void vkCmdResolveImage( VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageResolve* pRegions ) const\r
+ {\r
+ return ::vkCmdResolveImage( commandBuffer, srcImage, srcImageLayout, dstImage, dstImageLayout, regionCount, pRegions);\r
+ }\r
+ void vkCmdSetBlendConstants( VkCommandBuffer commandBuffer, const float blendConstants[4] ) const\r
+ {\r
+ return ::vkCmdSetBlendConstants( commandBuffer, blendConstants);\r
+ }\r
+ void vkCmdSetDepthBias( VkCommandBuffer commandBuffer, float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor ) const\r
+ {\r
+ return ::vkCmdSetDepthBias( commandBuffer, depthBiasConstantFactor, depthBiasClamp, depthBiasSlopeFactor);\r
+ }\r
+ void vkCmdSetDepthBounds( VkCommandBuffer commandBuffer, float minDepthBounds, float maxDepthBounds ) const\r
+ {\r
+ return ::vkCmdSetDepthBounds( commandBuffer, minDepthBounds, maxDepthBounds);\r
+ }\r
+ void vkCmdSetDeviceMask( VkCommandBuffer commandBuffer, uint32_t deviceMask ) const\r
+ {\r
+ return ::vkCmdSetDeviceMask( commandBuffer, deviceMask);\r
+ }\r
+ void vkCmdSetDeviceMaskKHR( VkCommandBuffer commandBuffer, uint32_t deviceMask ) const\r
+ {\r
+ return ::vkCmdSetDeviceMaskKHR( commandBuffer, deviceMask);\r
+ }\r
+ void vkCmdSetDiscardRectangleEXT( VkCommandBuffer commandBuffer, uint32_t firstDiscardRectangle, uint32_t discardRectangleCount, const VkRect2D* pDiscardRectangles ) const\r
+ {\r
+ return ::vkCmdSetDiscardRectangleEXT( commandBuffer, firstDiscardRectangle, discardRectangleCount, pDiscardRectangles);\r
+ }\r
+ void vkCmdSetEvent( VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask ) const\r
+ {\r
+ return ::vkCmdSetEvent( commandBuffer, event, stageMask);\r
+ }\r
+ void vkCmdSetLineWidth( VkCommandBuffer commandBuffer, float lineWidth ) const\r
+ {\r
+ return ::vkCmdSetLineWidth( commandBuffer, lineWidth);\r
+ }\r
+ void vkCmdSetSampleLocationsEXT( VkCommandBuffer commandBuffer, const VkSampleLocationsInfoEXT* pSampleLocationsInfo ) const\r
+ {\r
+ return ::vkCmdSetSampleLocationsEXT( commandBuffer, pSampleLocationsInfo);\r
+ }\r
+ void vkCmdSetScissor( VkCommandBuffer commandBuffer, uint32_t firstScissor, uint32_t scissorCount, const VkRect2D* pScissors ) const\r
+ {\r
+ return ::vkCmdSetScissor( commandBuffer, firstScissor, scissorCount, pScissors);\r
+ }\r
+ void vkCmdSetStencilCompareMask( VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t compareMask ) const\r
+ {\r
+ return ::vkCmdSetStencilCompareMask( commandBuffer, faceMask, compareMask);\r
+ }\r
+ void vkCmdSetStencilReference( VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t reference ) const\r
+ {\r
+ return ::vkCmdSetStencilReference( commandBuffer, faceMask, reference);\r
+ }\r
+ void vkCmdSetStencilWriteMask( VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t writeMask ) const\r
+ {\r
+ return ::vkCmdSetStencilWriteMask( commandBuffer, faceMask, writeMask);\r
+ }\r
+ void vkCmdSetViewport( VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewport* pViewports ) const\r
+ {\r
+ return ::vkCmdSetViewport( commandBuffer, firstViewport, viewportCount, pViewports);\r
+ }\r
+ void vkCmdSetViewportWScalingNV( VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewportWScalingNV* pViewportWScalings ) const\r
+ {\r
+ return ::vkCmdSetViewportWScalingNV( commandBuffer, firstViewport, viewportCount, pViewportWScalings);\r
+ }\r
+ void vkCmdUpdateBuffer( VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize dataSize, const void* pData ) const\r
+ {\r
+ return ::vkCmdUpdateBuffer( commandBuffer, dstBuffer, dstOffset, dataSize, pData);\r
+ }\r
+ void vkCmdWaitEvents( VkCommandBuffer commandBuffer, uint32_t eventCount, const VkEvent* pEvents, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers ) const\r
+ {\r
+ return ::vkCmdWaitEvents( commandBuffer, eventCount, pEvents, srcStageMask, dstStageMask, memoryBarrierCount, pMemoryBarriers, bufferMemoryBarrierCount, pBufferMemoryBarriers, imageMemoryBarrierCount, pImageMemoryBarriers);\r
+ }\r
+ void vkCmdWriteBufferMarkerAMD( VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkBuffer dstBuffer, VkDeviceSize dstOffset, uint32_t marker ) const\r
+ {\r
+ return ::vkCmdWriteBufferMarkerAMD( commandBuffer, pipelineStage, dstBuffer, dstOffset, marker);\r
+ }\r
+ void vkCmdWriteTimestamp( VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkQueryPool queryPool, uint32_t query ) const\r
+ {\r
+ return ::vkCmdWriteTimestamp( commandBuffer, pipelineStage, queryPool, query);\r
+ }\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ VkResult vkCreateAndroidSurfaceKHR( VkInstance instance, const VkAndroidSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateAndroidSurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+ VkResult vkCreateBuffer( VkDevice device, const VkBufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBuffer* pBuffer ) const\r
+ {\r
+ return ::vkCreateBuffer( device, pCreateInfo, pAllocator, pBuffer);\r
+ }\r
+ VkResult vkCreateBufferView( VkDevice device, const VkBufferViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBufferView* pView ) const\r
+ {\r
+ return ::vkCreateBufferView( device, pCreateInfo, pAllocator, pView);\r
+ }\r
+ VkResult vkCreateCommandPool( VkDevice device, const VkCommandPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkCommandPool* pCommandPool ) const\r
+ {\r
+ return ::vkCreateCommandPool( device, pCreateInfo, pAllocator, pCommandPool);\r
+ }\r
+ VkResult vkCreateComputePipelines( VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkComputePipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines ) const\r
+ {\r
+ return ::vkCreateComputePipelines( device, pipelineCache, createInfoCount, pCreateInfos, pAllocator, pPipelines);\r
+ }\r
+ VkResult vkCreateDebugReportCallbackEXT( VkInstance instance, const VkDebugReportCallbackCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugReportCallbackEXT* pCallback ) const\r
+ {\r
+ return ::vkCreateDebugReportCallbackEXT( instance, pCreateInfo, pAllocator, pCallback);\r
+ }\r
+ VkResult vkCreateDebugUtilsMessengerEXT( VkInstance instance, const VkDebugUtilsMessengerCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugUtilsMessengerEXT* pMessenger ) const\r
+ {\r
+ return ::vkCreateDebugUtilsMessengerEXT( instance, pCreateInfo, pAllocator, pMessenger);\r
+ }\r
+ VkResult vkCreateDescriptorPool( VkDevice device, const VkDescriptorPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorPool* pDescriptorPool ) const\r
+ {\r
+ return ::vkCreateDescriptorPool( device, pCreateInfo, pAllocator, pDescriptorPool);\r
+ }\r
+ VkResult vkCreateDescriptorSetLayout( VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorSetLayout* pSetLayout ) const\r
+ {\r
+ return ::vkCreateDescriptorSetLayout( device, pCreateInfo, pAllocator, pSetLayout);\r
+ }\r
+ VkResult vkCreateDescriptorUpdateTemplate( VkDevice device, const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate ) const\r
+ {\r
+ return ::vkCreateDescriptorUpdateTemplate( device, pCreateInfo, pAllocator, pDescriptorUpdateTemplate);\r
+ }\r
+ VkResult vkCreateDescriptorUpdateTemplateKHR( VkDevice device, const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate ) const\r
+ {\r
+ return ::vkCreateDescriptorUpdateTemplateKHR( device, pCreateInfo, pAllocator, pDescriptorUpdateTemplate);\r
+ }\r
+ VkResult vkCreateDevice( VkPhysicalDevice physicalDevice, const VkDeviceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDevice* pDevice ) const\r
+ {\r
+ return ::vkCreateDevice( physicalDevice, pCreateInfo, pAllocator, pDevice);\r
+ }\r
+ VkResult vkCreateDisplayModeKHR( VkPhysicalDevice physicalDevice, VkDisplayKHR display, const VkDisplayModeCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDisplayModeKHR* pMode ) const\r
+ {\r
+ return ::vkCreateDisplayModeKHR( physicalDevice, display, pCreateInfo, pAllocator, pMode);\r
+ }\r
+ VkResult vkCreateDisplayPlaneSurfaceKHR( VkInstance instance, const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateDisplayPlaneSurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+ VkResult vkCreateEvent( VkDevice device, const VkEventCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkEvent* pEvent ) const\r
+ {\r
+ return ::vkCreateEvent( device, pCreateInfo, pAllocator, pEvent);\r
+ }\r
+ VkResult vkCreateFence( VkDevice device, const VkFenceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence ) const\r
+ {\r
+ return ::vkCreateFence( device, pCreateInfo, pAllocator, pFence);\r
+ }\r
+ VkResult vkCreateFramebuffer( VkDevice device, const VkFramebufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFramebuffer* pFramebuffer ) const\r
+ {\r
+ return ::vkCreateFramebuffer( device, pCreateInfo, pAllocator, pFramebuffer);\r
+ }\r
+ VkResult vkCreateGraphicsPipelines( VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkGraphicsPipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines ) const\r
+ {\r
+ return ::vkCreateGraphicsPipelines( device, pipelineCache, createInfoCount, pCreateInfos, pAllocator, pPipelines);\r
+ }\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ VkResult vkCreateIOSSurfaceMVK( VkInstance instance, const VkIOSSurfaceCreateInfoMVK* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateIOSSurfaceMVK( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+ VkResult vkCreateImage( VkDevice device, const VkImageCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImage* pImage ) const\r
+ {\r
+ return ::vkCreateImage( device, pCreateInfo, pAllocator, pImage);\r
+ }\r
+ VkResult vkCreateImageView( VkDevice device, const VkImageViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImageView* pView ) const\r
+ {\r
+ return ::vkCreateImageView( device, pCreateInfo, pAllocator, pView);\r
+ }\r
+ VkResult vkCreateIndirectCommandsLayoutNVX( VkDevice device, const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout ) const\r
+ {\r
+ return ::vkCreateIndirectCommandsLayoutNVX( device, pCreateInfo, pAllocator, pIndirectCommandsLayout);\r
+ }\r
+ VkResult vkCreateInstance( const VkInstanceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkInstance* pInstance ) const\r
+ {\r
+ return ::vkCreateInstance( pCreateInfo, pAllocator, pInstance);\r
+ }\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ VkResult vkCreateMacOSSurfaceMVK( VkInstance instance, const VkMacOSSurfaceCreateInfoMVK* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateMacOSSurfaceMVK( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ VkResult vkCreateMirSurfaceKHR( VkInstance instance, const VkMirSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateMirSurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+ VkResult vkCreateObjectTableNVX( VkDevice device, const VkObjectTableCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkObjectTableNVX* pObjectTable ) const\r
+ {\r
+ return ::vkCreateObjectTableNVX( device, pCreateInfo, pAllocator, pObjectTable);\r
+ }\r
+ VkResult vkCreatePipelineCache( VkDevice device, const VkPipelineCacheCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineCache* pPipelineCache ) const\r
+ {\r
+ return ::vkCreatePipelineCache( device, pCreateInfo, pAllocator, pPipelineCache);\r
+ }\r
+ VkResult vkCreatePipelineLayout( VkDevice device, const VkPipelineLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineLayout* pPipelineLayout ) const\r
+ {\r
+ return ::vkCreatePipelineLayout( device, pCreateInfo, pAllocator, pPipelineLayout);\r
+ }\r
+ VkResult vkCreateQueryPool( VkDevice device, const VkQueryPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkQueryPool* pQueryPool ) const\r
+ {\r
+ return ::vkCreateQueryPool( device, pCreateInfo, pAllocator, pQueryPool);\r
+ }\r
+ VkResult vkCreateRenderPass( VkDevice device, const VkRenderPassCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkRenderPass* pRenderPass ) const\r
+ {\r
+ return ::vkCreateRenderPass( device, pCreateInfo, pAllocator, pRenderPass);\r
+ }\r
+ VkResult vkCreateSampler( VkDevice device, const VkSamplerCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSampler* pSampler ) const\r
+ {\r
+ return ::vkCreateSampler( device, pCreateInfo, pAllocator, pSampler);\r
+ }\r
+ VkResult vkCreateSamplerYcbcrConversion( VkDevice device, const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSamplerYcbcrConversion* pYcbcrConversion ) const\r
+ {\r
+ return ::vkCreateSamplerYcbcrConversion( device, pCreateInfo, pAllocator, pYcbcrConversion);\r
+ }\r
+ VkResult vkCreateSamplerYcbcrConversionKHR( VkDevice device, const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSamplerYcbcrConversion* pYcbcrConversion ) const\r
+ {\r
+ return ::vkCreateSamplerYcbcrConversionKHR( device, pCreateInfo, pAllocator, pYcbcrConversion);\r
+ }\r
+ VkResult vkCreateSemaphore( VkDevice device, const VkSemaphoreCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSemaphore* pSemaphore ) const\r
+ {\r
+ return ::vkCreateSemaphore( device, pCreateInfo, pAllocator, pSemaphore);\r
+ }\r
+ VkResult vkCreateShaderModule( VkDevice device, const VkShaderModuleCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkShaderModule* pShaderModule ) const\r
+ {\r
+ return ::vkCreateShaderModule( device, pCreateInfo, pAllocator, pShaderModule);\r
+ }\r
+ VkResult vkCreateSharedSwapchainsKHR( VkDevice device, uint32_t swapchainCount, const VkSwapchainCreateInfoKHR* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchains ) const\r
+ {\r
+ return ::vkCreateSharedSwapchainsKHR( device, swapchainCount, pCreateInfos, pAllocator, pSwapchains);\r
+ }\r
+ VkResult vkCreateSwapchainKHR( VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain ) const\r
+ {\r
+ return ::vkCreateSwapchainKHR( device, pCreateInfo, pAllocator, pSwapchain);\r
+ }\r
+ VkResult vkCreateValidationCacheEXT( VkDevice device, const VkValidationCacheCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkValidationCacheEXT* pValidationCache ) const\r
+ {\r
+ return ::vkCreateValidationCacheEXT( device, pCreateInfo, pAllocator, pValidationCache);\r
+ }\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ VkResult vkCreateViSurfaceNN( VkInstance instance, const VkViSurfaceCreateInfoNN* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateViSurfaceNN( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ VkResult vkCreateWaylandSurfaceKHR( VkInstance instance, const VkWaylandSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateWaylandSurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkCreateWin32SurfaceKHR( VkInstance instance, const VkWin32SurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateWin32SurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ VkResult vkCreateXcbSurfaceKHR( VkInstance instance, const VkXcbSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateXcbSurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ VkResult vkCreateXlibSurfaceKHR( VkInstance instance, const VkXlibSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface ) const\r
+ {\r
+ return ::vkCreateXlibSurfaceKHR( instance, pCreateInfo, pAllocator, pSurface);\r
+ }\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+ VkResult vkDebugMarkerSetObjectNameEXT( VkDevice device, const VkDebugMarkerObjectNameInfoEXT* pNameInfo ) const\r
+ {\r
+ return ::vkDebugMarkerSetObjectNameEXT( device, pNameInfo);\r
+ }\r
+ VkResult vkDebugMarkerSetObjectTagEXT( VkDevice device, const VkDebugMarkerObjectTagInfoEXT* pTagInfo ) const\r
+ {\r
+ return ::vkDebugMarkerSetObjectTagEXT( device, pTagInfo);\r
+ }\r
+ void vkDebugReportMessageEXT( VkInstance instance, VkDebugReportFlagsEXT flags, VkDebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const char* pLayerPrefix, const char* pMessage ) const\r
+ {\r
+ return ::vkDebugReportMessageEXT( instance, flags, objectType, object, location, messageCode, pLayerPrefix, pMessage);\r
+ }\r
+ void vkDestroyBuffer( VkDevice device, VkBuffer buffer, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyBuffer( device, buffer, pAllocator);\r
+ }\r
+ void vkDestroyBufferView( VkDevice device, VkBufferView bufferView, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyBufferView( device, bufferView, pAllocator);\r
+ }\r
+ void vkDestroyCommandPool( VkDevice device, VkCommandPool commandPool, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyCommandPool( device, commandPool, pAllocator);\r
+ }\r
+ void vkDestroyDebugReportCallbackEXT( VkInstance instance, VkDebugReportCallbackEXT callback, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDebugReportCallbackEXT( instance, callback, pAllocator);\r
+ }\r
+ void vkDestroyDebugUtilsMessengerEXT( VkInstance instance, VkDebugUtilsMessengerEXT messenger, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDebugUtilsMessengerEXT( instance, messenger, pAllocator);\r
+ }\r
+ void vkDestroyDescriptorPool( VkDevice device, VkDescriptorPool descriptorPool, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDescriptorPool( device, descriptorPool, pAllocator);\r
+ }\r
+ void vkDestroyDescriptorSetLayout( VkDevice device, VkDescriptorSetLayout descriptorSetLayout, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDescriptorSetLayout( device, descriptorSetLayout, pAllocator);\r
+ }\r
+ void vkDestroyDescriptorUpdateTemplate( VkDevice device, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDescriptorUpdateTemplate( device, descriptorUpdateTemplate, pAllocator);\r
+ }\r
+ void vkDestroyDescriptorUpdateTemplateKHR( VkDevice device, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDescriptorUpdateTemplateKHR( device, descriptorUpdateTemplate, pAllocator);\r
+ }\r
+ void vkDestroyDevice( VkDevice device, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyDevice( device, pAllocator);\r
+ }\r
+ void vkDestroyEvent( VkDevice device, VkEvent event, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyEvent( device, event, pAllocator);\r
+ }\r
+ void vkDestroyFence( VkDevice device, VkFence fence, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyFence( device, fence, pAllocator);\r
+ }\r
+ void vkDestroyFramebuffer( VkDevice device, VkFramebuffer framebuffer, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyFramebuffer( device, framebuffer, pAllocator);\r
+ }\r
+ void vkDestroyImage( VkDevice device, VkImage image, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyImage( device, image, pAllocator);\r
+ }\r
+ void vkDestroyImageView( VkDevice device, VkImageView imageView, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyImageView( device, imageView, pAllocator);\r
+ }\r
+ void vkDestroyIndirectCommandsLayoutNVX( VkDevice device, VkIndirectCommandsLayoutNVX indirectCommandsLayout, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyIndirectCommandsLayoutNVX( device, indirectCommandsLayout, pAllocator);\r
+ }\r
+ void vkDestroyInstance( VkInstance instance, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyInstance( instance, pAllocator);\r
+ }\r
+ void vkDestroyObjectTableNVX( VkDevice device, VkObjectTableNVX objectTable, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyObjectTableNVX( device, objectTable, pAllocator);\r
+ }\r
+ void vkDestroyPipeline( VkDevice device, VkPipeline pipeline, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyPipeline( device, pipeline, pAllocator);\r
+ }\r
+ void vkDestroyPipelineCache( VkDevice device, VkPipelineCache pipelineCache, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyPipelineCache( device, pipelineCache, pAllocator);\r
+ }\r
+ void vkDestroyPipelineLayout( VkDevice device, VkPipelineLayout pipelineLayout, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyPipelineLayout( device, pipelineLayout, pAllocator);\r
+ }\r
+ void vkDestroyQueryPool( VkDevice device, VkQueryPool queryPool, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyQueryPool( device, queryPool, pAllocator);\r
+ }\r
+ void vkDestroyRenderPass( VkDevice device, VkRenderPass renderPass, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyRenderPass( device, renderPass, pAllocator);\r
+ }\r
+ void vkDestroySampler( VkDevice device, VkSampler sampler, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroySampler( device, sampler, pAllocator);\r
+ }\r
+ void vkDestroySamplerYcbcrConversion( VkDevice device, VkSamplerYcbcrConversion ycbcrConversion, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroySamplerYcbcrConversion( device, ycbcrConversion, pAllocator);\r
+ }\r
+ void vkDestroySamplerYcbcrConversionKHR( VkDevice device, VkSamplerYcbcrConversion ycbcrConversion, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroySamplerYcbcrConversionKHR( device, ycbcrConversion, pAllocator);\r
+ }\r
+ void vkDestroySemaphore( VkDevice device, VkSemaphore semaphore, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroySemaphore( device, semaphore, pAllocator);\r
+ }\r
+ void vkDestroyShaderModule( VkDevice device, VkShaderModule shaderModule, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyShaderModule( device, shaderModule, pAllocator);\r
+ }\r
+ void vkDestroySurfaceKHR( VkInstance instance, VkSurfaceKHR surface, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroySurfaceKHR( instance, surface, pAllocator);\r
+ }\r
+ void vkDestroySwapchainKHR( VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroySwapchainKHR( device, swapchain, pAllocator);\r
+ }\r
+ void vkDestroyValidationCacheEXT( VkDevice device, VkValidationCacheEXT validationCache, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkDestroyValidationCacheEXT( device, validationCache, pAllocator);\r
+ }\r
+ VkResult vkDeviceWaitIdle( VkDevice device ) const\r
+ {\r
+ return ::vkDeviceWaitIdle( device);\r
+ }\r
+ VkResult vkDisplayPowerControlEXT( VkDevice device, VkDisplayKHR display, const VkDisplayPowerInfoEXT* pDisplayPowerInfo ) const\r
+ {\r
+ return ::vkDisplayPowerControlEXT( device, display, pDisplayPowerInfo);\r
+ }\r
+ VkResult vkEndCommandBuffer( VkCommandBuffer commandBuffer ) const\r
+ {\r
+ return ::vkEndCommandBuffer( commandBuffer);\r
+ }\r
+ VkResult vkEnumerateDeviceExtensionProperties( VkPhysicalDevice physicalDevice, const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties ) const\r
+ {\r
+ return ::vkEnumerateDeviceExtensionProperties( physicalDevice, pLayerName, pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkEnumerateDeviceLayerProperties( VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkLayerProperties* pProperties ) const\r
+ {\r
+ return ::vkEnumerateDeviceLayerProperties( physicalDevice, pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkEnumerateInstanceExtensionProperties( const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties ) const\r
+ {\r
+ return ::vkEnumerateInstanceExtensionProperties( pLayerName, pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkEnumerateInstanceLayerProperties( uint32_t* pPropertyCount, VkLayerProperties* pProperties ) const\r
+ {\r
+ return ::vkEnumerateInstanceLayerProperties( pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkEnumerateInstanceVersion( uint32_t* pApiVersion ) const\r
+ {\r
+ return ::vkEnumerateInstanceVersion( pApiVersion);\r
+ }\r
+ VkResult vkEnumeratePhysicalDeviceGroups( VkInstance instance, uint32_t* pPhysicalDeviceGroupCount, VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties ) const\r
+ {\r
+ return ::vkEnumeratePhysicalDeviceGroups( instance, pPhysicalDeviceGroupCount, pPhysicalDeviceGroupProperties);\r
+ }\r
+ VkResult vkEnumeratePhysicalDeviceGroupsKHR( VkInstance instance, uint32_t* pPhysicalDeviceGroupCount, VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties ) const\r
+ {\r
+ return ::vkEnumeratePhysicalDeviceGroupsKHR( instance, pPhysicalDeviceGroupCount, pPhysicalDeviceGroupProperties);\r
+ }\r
+ VkResult vkEnumeratePhysicalDevices( VkInstance instance, uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices ) const\r
+ {\r
+ return ::vkEnumeratePhysicalDevices( instance, pPhysicalDeviceCount, pPhysicalDevices);\r
+ }\r
+ VkResult vkFlushMappedMemoryRanges( VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges ) const\r
+ {\r
+ return ::vkFlushMappedMemoryRanges( device, memoryRangeCount, pMemoryRanges);\r
+ }\r
+ void vkFreeCommandBuffers( VkDevice device, VkCommandPool commandPool, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers ) const\r
+ {\r
+ return ::vkFreeCommandBuffers( device, commandPool, commandBufferCount, pCommandBuffers);\r
+ }\r
+ VkResult vkFreeDescriptorSets( VkDevice device, VkDescriptorPool descriptorPool, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets ) const\r
+ {\r
+ return ::vkFreeDescriptorSets( device, descriptorPool, descriptorSetCount, pDescriptorSets);\r
+ }\r
+ void vkFreeMemory( VkDevice device, VkDeviceMemory memory, const VkAllocationCallbacks* pAllocator ) const\r
+ {\r
+ return ::vkFreeMemory( device, memory, pAllocator);\r
+ }\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ VkResult vkGetAndroidHardwareBufferPropertiesANDROID( VkDevice device, const struct AHardwareBuffer* buffer, VkAndroidHardwareBufferPropertiesANDROID* pProperties ) const\r
+ {\r
+ return ::vkGetAndroidHardwareBufferPropertiesANDROID( device, buffer, pProperties);\r
+ }\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ void vkGetBufferMemoryRequirements( VkDevice device, VkBuffer buffer, VkMemoryRequirements* pMemoryRequirements ) const\r
+ {\r
+ return ::vkGetBufferMemoryRequirements( device, buffer, pMemoryRequirements);\r
+ }\r
+ void vkGetBufferMemoryRequirements2( VkDevice device, const VkBufferMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements ) const\r
+ {\r
+ return ::vkGetBufferMemoryRequirements2( device, pInfo, pMemoryRequirements);\r
+ }\r
+ void vkGetBufferMemoryRequirements2KHR( VkDevice device, const VkBufferMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements ) const\r
+ {\r
+ return ::vkGetBufferMemoryRequirements2KHR( device, pInfo, pMemoryRequirements);\r
+ }\r
+ void vkGetDescriptorSetLayoutSupport( VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, VkDescriptorSetLayoutSupport* pSupport ) const\r
+ {\r
+ return ::vkGetDescriptorSetLayoutSupport( device, pCreateInfo, pSupport);\r
+ }\r
+ void vkGetDescriptorSetLayoutSupportKHR( VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, VkDescriptorSetLayoutSupport* pSupport ) const\r
+ {\r
+ return ::vkGetDescriptorSetLayoutSupportKHR( device, pCreateInfo, pSupport);\r
+ }\r
+ void vkGetDeviceGroupPeerMemoryFeatures( VkDevice device, uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, VkPeerMemoryFeatureFlags* pPeerMemoryFeatures ) const\r
+ {\r
+ return ::vkGetDeviceGroupPeerMemoryFeatures( device, heapIndex, localDeviceIndex, remoteDeviceIndex, pPeerMemoryFeatures);\r
+ }\r
+ void vkGetDeviceGroupPeerMemoryFeaturesKHR( VkDevice device, uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, VkPeerMemoryFeatureFlags* pPeerMemoryFeatures ) const\r
+ {\r
+ return ::vkGetDeviceGroupPeerMemoryFeaturesKHR( device, heapIndex, localDeviceIndex, remoteDeviceIndex, pPeerMemoryFeatures);\r
+ }\r
+ VkResult vkGetDeviceGroupPresentCapabilitiesKHR( VkDevice device, VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities ) const\r
+ {\r
+ return ::vkGetDeviceGroupPresentCapabilitiesKHR( device, pDeviceGroupPresentCapabilities);\r
+ }\r
+ VkResult vkGetDeviceGroupSurfacePresentModesKHR( VkDevice device, VkSurfaceKHR surface, VkDeviceGroupPresentModeFlagsKHR* pModes ) const\r
+ {\r
+ return ::vkGetDeviceGroupSurfacePresentModesKHR( device, surface, pModes);\r
+ }\r
+ void vkGetDeviceMemoryCommitment( VkDevice device, VkDeviceMemory memory, VkDeviceSize* pCommittedMemoryInBytes ) const\r
+ {\r
+ return ::vkGetDeviceMemoryCommitment( device, memory, pCommittedMemoryInBytes);\r
+ }\r
+ PFN_vkVoidFunction vkGetDeviceProcAddr( VkDevice device, const char* pName ) const\r
+ {\r
+ return ::vkGetDeviceProcAddr( device, pName);\r
+ }\r
+ void vkGetDeviceQueue( VkDevice device, uint32_t queueFamilyIndex, uint32_t queueIndex, VkQueue* pQueue ) const\r
+ {\r
+ return ::vkGetDeviceQueue( device, queueFamilyIndex, queueIndex, pQueue);\r
+ }\r
+ void vkGetDeviceQueue2( VkDevice device, const VkDeviceQueueInfo2* pQueueInfo, VkQueue* pQueue ) const\r
+ {\r
+ return ::vkGetDeviceQueue2( device, pQueueInfo, pQueue);\r
+ }\r
+ VkResult vkGetDisplayModePropertiesKHR( VkPhysicalDevice physicalDevice, VkDisplayKHR display, uint32_t* pPropertyCount, VkDisplayModePropertiesKHR* pProperties ) const\r
+ {\r
+ return ::vkGetDisplayModePropertiesKHR( physicalDevice, display, pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkGetDisplayPlaneCapabilitiesKHR( VkPhysicalDevice physicalDevice, VkDisplayModeKHR mode, uint32_t planeIndex, VkDisplayPlaneCapabilitiesKHR* pCapabilities ) const\r
+ {\r
+ return ::vkGetDisplayPlaneCapabilitiesKHR( physicalDevice, mode, planeIndex, pCapabilities);\r
+ }\r
+ VkResult vkGetDisplayPlaneSupportedDisplaysKHR( VkPhysicalDevice physicalDevice, uint32_t planeIndex, uint32_t* pDisplayCount, VkDisplayKHR* pDisplays ) const\r
+ {\r
+ return ::vkGetDisplayPlaneSupportedDisplaysKHR( physicalDevice, planeIndex, pDisplayCount, pDisplays);\r
+ }\r
+ VkResult vkGetEventStatus( VkDevice device, VkEvent event ) const\r
+ {\r
+ return ::vkGetEventStatus( device, event);\r
+ }\r
+ VkResult vkGetFenceFdKHR( VkDevice device, const VkFenceGetFdInfoKHR* pGetFdInfo, int* pFd ) const\r
+ {\r
+ return ::vkGetFenceFdKHR( device, pGetFdInfo, pFd);\r
+ }\r
+ VkResult vkGetFenceStatus( VkDevice device, VkFence fence ) const\r
+ {\r
+ return ::vkGetFenceStatus( device, fence);\r
+ }\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkGetFenceWin32HandleKHR( VkDevice device, const VkFenceGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle ) const\r
+ {\r
+ return ::vkGetFenceWin32HandleKHR( device, pGetWin32HandleInfo, pHandle);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ void vkGetImageMemoryRequirements( VkDevice device, VkImage image, VkMemoryRequirements* pMemoryRequirements ) const\r
+ {\r
+ return ::vkGetImageMemoryRequirements( device, image, pMemoryRequirements);\r
+ }\r
+ void vkGetImageMemoryRequirements2( VkDevice device, const VkImageMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements ) const\r
+ {\r
+ return ::vkGetImageMemoryRequirements2( device, pInfo, pMemoryRequirements);\r
+ }\r
+ void vkGetImageMemoryRequirements2KHR( VkDevice device, const VkImageMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements ) const\r
+ {\r
+ return ::vkGetImageMemoryRequirements2KHR( device, pInfo, pMemoryRequirements);\r
+ }\r
+ void vkGetImageSparseMemoryRequirements( VkDevice device, VkImage image, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements* pSparseMemoryRequirements ) const\r
+ {\r
+ return ::vkGetImageSparseMemoryRequirements( device, image, pSparseMemoryRequirementCount, pSparseMemoryRequirements);\r
+ }\r
+ void vkGetImageSparseMemoryRequirements2( VkDevice device, const VkImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements2* pSparseMemoryRequirements ) const\r
+ {\r
+ return ::vkGetImageSparseMemoryRequirements2( device, pInfo, pSparseMemoryRequirementCount, pSparseMemoryRequirements);\r
+ }\r
+ void vkGetImageSparseMemoryRequirements2KHR( VkDevice device, const VkImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements2* pSparseMemoryRequirements ) const\r
+ {\r
+ return ::vkGetImageSparseMemoryRequirements2KHR( device, pInfo, pSparseMemoryRequirementCount, pSparseMemoryRequirements);\r
+ }\r
+ void vkGetImageSubresourceLayout( VkDevice device, VkImage image, const VkImageSubresource* pSubresource, VkSubresourceLayout* pLayout ) const\r
+ {\r
+ return ::vkGetImageSubresourceLayout( device, image, pSubresource, pLayout);\r
+ }\r
+ PFN_vkVoidFunction vkGetInstanceProcAddr( VkInstance instance, const char* pName ) const\r
+ {\r
+ return ::vkGetInstanceProcAddr( instance, pName);\r
+ }\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ VkResult vkGetMemoryAndroidHardwareBufferANDROID( VkDevice device, const VkMemoryGetAndroidHardwareBufferInfoANDROID* pInfo, struct AHardwareBuffer** pBuffer ) const\r
+ {\r
+ return ::vkGetMemoryAndroidHardwareBufferANDROID( device, pInfo, pBuffer);\r
+ }\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ VkResult vkGetMemoryFdKHR( VkDevice device, const VkMemoryGetFdInfoKHR* pGetFdInfo, int* pFd ) const\r
+ {\r
+ return ::vkGetMemoryFdKHR( device, pGetFdInfo, pFd);\r
+ }\r
+ VkResult vkGetMemoryFdPropertiesKHR( VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, int fd, VkMemoryFdPropertiesKHR* pMemoryFdProperties ) const\r
+ {\r
+ return ::vkGetMemoryFdPropertiesKHR( device, handleType, fd, pMemoryFdProperties);\r
+ }\r
+ VkResult vkGetMemoryHostPointerPropertiesEXT( VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, VkMemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties ) const\r
+ {\r
+ return ::vkGetMemoryHostPointerPropertiesEXT( device, handleType, pHostPointer, pMemoryHostPointerProperties);\r
+ }\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkGetMemoryWin32HandleKHR( VkDevice device, const VkMemoryGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle ) const\r
+ {\r
+ return ::vkGetMemoryWin32HandleKHR( device, pGetWin32HandleInfo, pHandle);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ VkResult vkGetMemoryWin32HandleNV( VkDevice device, VkDeviceMemory memory, VkExternalMemoryHandleTypeFlagsNV handleType, HANDLE* pHandle ) const\r
+ {\r
+ return ::vkGetMemoryWin32HandleNV( device, memory, handleType, pHandle);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkGetMemoryWin32HandlePropertiesKHR( VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, HANDLE handle, VkMemoryWin32HandlePropertiesKHR* pMemoryWin32HandleProperties ) const\r
+ {\r
+ return ::vkGetMemoryWin32HandlePropertiesKHR( device, handleType, handle, pMemoryWin32HandleProperties);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ VkResult vkGetPastPresentationTimingGOOGLE( VkDevice device, VkSwapchainKHR swapchain, uint32_t* pPresentationTimingCount, VkPastPresentationTimingGOOGLE* pPresentationTimings ) const\r
+ {\r
+ return ::vkGetPastPresentationTimingGOOGLE( device, swapchain, pPresentationTimingCount, pPresentationTimings);\r
+ }\r
+ VkResult vkGetPhysicalDeviceDisplayPlanePropertiesKHR( VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPlanePropertiesKHR* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceDisplayPlanePropertiesKHR( physicalDevice, pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkGetPhysicalDeviceDisplayPropertiesKHR( VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPropertiesKHR* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceDisplayPropertiesKHR( physicalDevice, pPropertyCount, pProperties);\r
+ }\r
+ void vkGetPhysicalDeviceExternalBufferProperties( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, VkExternalBufferProperties* pExternalBufferProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalBufferProperties( physicalDevice, pExternalBufferInfo, pExternalBufferProperties);\r
+ }\r
+ void vkGetPhysicalDeviceExternalBufferPropertiesKHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, VkExternalBufferProperties* pExternalBufferProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalBufferPropertiesKHR( physicalDevice, pExternalBufferInfo, pExternalBufferProperties);\r
+ }\r
+ void vkGetPhysicalDeviceExternalFenceProperties( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, VkExternalFenceProperties* pExternalFenceProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalFenceProperties( physicalDevice, pExternalFenceInfo, pExternalFenceProperties);\r
+ }\r
+ void vkGetPhysicalDeviceExternalFencePropertiesKHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, VkExternalFenceProperties* pExternalFenceProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalFencePropertiesKHR( physicalDevice, pExternalFenceInfo, pExternalFenceProperties);\r
+ }\r
+ VkResult vkGetPhysicalDeviceExternalImageFormatPropertiesNV( VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkExternalMemoryHandleTypeFlagsNV externalHandleType, VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalImageFormatPropertiesNV( physicalDevice, format, type, tiling, usage, flags, externalHandleType, pExternalImageFormatProperties);\r
+ }\r
+ void vkGetPhysicalDeviceExternalSemaphoreProperties( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, VkExternalSemaphoreProperties* pExternalSemaphoreProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalSemaphoreProperties( physicalDevice, pExternalSemaphoreInfo, pExternalSemaphoreProperties);\r
+ }\r
+ void vkGetPhysicalDeviceExternalSemaphorePropertiesKHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, VkExternalSemaphoreProperties* pExternalSemaphoreProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceExternalSemaphorePropertiesKHR( physicalDevice, pExternalSemaphoreInfo, pExternalSemaphoreProperties);\r
+ }\r
+ void vkGetPhysicalDeviceFeatures( VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures* pFeatures ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceFeatures( physicalDevice, pFeatures);\r
+ }\r
+ void vkGetPhysicalDeviceFeatures2( VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2* pFeatures ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceFeatures2( physicalDevice, pFeatures);\r
+ }\r
+ void vkGetPhysicalDeviceFeatures2KHR( VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2* pFeatures ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceFeatures2KHR( physicalDevice, pFeatures);\r
+ }\r
+ void vkGetPhysicalDeviceFormatProperties( VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties* pFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceFormatProperties( physicalDevice, format, pFormatProperties);\r
+ }\r
+ void vkGetPhysicalDeviceFormatProperties2( VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2* pFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceFormatProperties2( physicalDevice, format, pFormatProperties);\r
+ }\r
+ void vkGetPhysicalDeviceFormatProperties2KHR( VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2* pFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceFormatProperties2KHR( physicalDevice, format, pFormatProperties);\r
+ }\r
+ void vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX( VkPhysicalDevice physicalDevice, VkDeviceGeneratedCommandsFeaturesNVX* pFeatures, VkDeviceGeneratedCommandsLimitsNVX* pLimits ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX( physicalDevice, pFeatures, pLimits);\r
+ }\r
+ VkResult vkGetPhysicalDeviceImageFormatProperties( VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkImageFormatProperties* pImageFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceImageFormatProperties( physicalDevice, format, type, tiling, usage, flags, pImageFormatProperties);\r
+ }\r
+ VkResult vkGetPhysicalDeviceImageFormatProperties2( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, VkImageFormatProperties2* pImageFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceImageFormatProperties2( physicalDevice, pImageFormatInfo, pImageFormatProperties);\r
+ }\r
+ VkResult vkGetPhysicalDeviceImageFormatProperties2KHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, VkImageFormatProperties2* pImageFormatProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceImageFormatProperties2KHR( physicalDevice, pImageFormatInfo, pImageFormatProperties);\r
+ }\r
+ void vkGetPhysicalDeviceMemoryProperties( VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties* pMemoryProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceMemoryProperties( physicalDevice, pMemoryProperties);\r
+ }\r
+ void vkGetPhysicalDeviceMemoryProperties2( VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2* pMemoryProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceMemoryProperties2( physicalDevice, pMemoryProperties);\r
+ }\r
+ void vkGetPhysicalDeviceMemoryProperties2KHR( VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2* pMemoryProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceMemoryProperties2KHR( physicalDevice, pMemoryProperties);\r
+ }\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ VkBool32 vkGetPhysicalDeviceMirPresentationSupportKHR( VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, MirConnection* connection ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceMirPresentationSupportKHR( physicalDevice, queueFamilyIndex, connection);\r
+ }\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+ void vkGetPhysicalDeviceMultisamplePropertiesEXT( VkPhysicalDevice physicalDevice, VkSampleCountFlagBits samples, VkMultisamplePropertiesEXT* pMultisampleProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceMultisamplePropertiesEXT( physicalDevice, samples, pMultisampleProperties);\r
+ }\r
+ VkResult vkGetPhysicalDevicePresentRectanglesKHR( VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pRectCount, VkRect2D* pRects ) const\r
+ {\r
+ return ::vkGetPhysicalDevicePresentRectanglesKHR( physicalDevice, surface, pRectCount, pRects);\r
+ }\r
+ void vkGetPhysicalDeviceProperties( VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceProperties( physicalDevice, pProperties);\r
+ }\r
+ void vkGetPhysicalDeviceProperties2( VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceProperties2( physicalDevice, pProperties);\r
+ }\r
+ void vkGetPhysicalDeviceProperties2KHR( VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceProperties2KHR( physicalDevice, pProperties);\r
+ }\r
+ void vkGetPhysicalDeviceQueueFamilyProperties( VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties* pQueueFamilyProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceQueueFamilyProperties( physicalDevice, pQueueFamilyPropertyCount, pQueueFamilyProperties);\r
+ }\r
+ void vkGetPhysicalDeviceQueueFamilyProperties2( VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2* pQueueFamilyProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceQueueFamilyProperties2( physicalDevice, pQueueFamilyPropertyCount, pQueueFamilyProperties);\r
+ }\r
+ void vkGetPhysicalDeviceQueueFamilyProperties2KHR( VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2* pQueueFamilyProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceQueueFamilyProperties2KHR( physicalDevice, pQueueFamilyPropertyCount, pQueueFamilyProperties);\r
+ }\r
+ void vkGetPhysicalDeviceSparseImageFormatProperties( VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkSampleCountFlagBits samples, VkImageUsageFlags usage, VkImageTiling tiling, uint32_t* pPropertyCount, VkSparseImageFormatProperties* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSparseImageFormatProperties( physicalDevice, format, type, samples, usage, tiling, pPropertyCount, pProperties);\r
+ }\r
+ void vkGetPhysicalDeviceSparseImageFormatProperties2( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSparseImageFormatProperties2( physicalDevice, pFormatInfo, pPropertyCount, pProperties);\r
+ }\r
+ void vkGetPhysicalDeviceSparseImageFormatProperties2KHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2* pProperties ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSparseImageFormatProperties2KHR( physicalDevice, pFormatInfo, pPropertyCount, pProperties);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfaceCapabilities2EXT( VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilities2EXT* pSurfaceCapabilities ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfaceCapabilities2EXT( physicalDevice, surface, pSurfaceCapabilities);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfaceCapabilities2KHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, VkSurfaceCapabilities2KHR* pSurfaceCapabilities ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfaceCapabilities2KHR( physicalDevice, pSurfaceInfo, pSurfaceCapabilities);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfaceCapabilitiesKHR( VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilitiesKHR* pSurfaceCapabilities ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfaceCapabilitiesKHR( physicalDevice, surface, pSurfaceCapabilities);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfaceFormats2KHR( VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, uint32_t* pSurfaceFormatCount, VkSurfaceFormat2KHR* pSurfaceFormats ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfaceFormats2KHR( physicalDevice, pSurfaceInfo, pSurfaceFormatCount, pSurfaceFormats);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfaceFormatsKHR( VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pSurfaceFormatCount, VkSurfaceFormatKHR* pSurfaceFormats ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfaceFormatsKHR( physicalDevice, surface, pSurfaceFormatCount, pSurfaceFormats);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfacePresentModesKHR( VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pPresentModeCount, VkPresentModeKHR* pPresentModes ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfacePresentModesKHR( physicalDevice, surface, pPresentModeCount, pPresentModes);\r
+ }\r
+ VkResult vkGetPhysicalDeviceSurfaceSupportKHR( VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, VkSurfaceKHR surface, VkBool32* pSupported ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceSurfaceSupportKHR( physicalDevice, queueFamilyIndex, surface, pSupported);\r
+ }\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ VkBool32 vkGetPhysicalDeviceWaylandPresentationSupportKHR( VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, struct wl_display* display ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceWaylandPresentationSupportKHR( physicalDevice, queueFamilyIndex, display);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkBool32 vkGetPhysicalDeviceWin32PresentationSupportKHR( VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceWin32PresentationSupportKHR( physicalDevice, queueFamilyIndex);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ VkBool32 vkGetPhysicalDeviceXcbPresentationSupportKHR( VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, xcb_connection_t* connection, xcb_visualid_t visual_id ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceXcbPresentationSupportKHR( physicalDevice, queueFamilyIndex, connection, visual_id);\r
+ }\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ VkBool32 vkGetPhysicalDeviceXlibPresentationSupportKHR( VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, Display* dpy, VisualID visualID ) const\r
+ {\r
+ return ::vkGetPhysicalDeviceXlibPresentationSupportKHR( physicalDevice, queueFamilyIndex, dpy, visualID);\r
+ }\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+ VkResult vkGetPipelineCacheData( VkDevice device, VkPipelineCache pipelineCache, size_t* pDataSize, void* pData ) const\r
+ {\r
+ return ::vkGetPipelineCacheData( device, pipelineCache, pDataSize, pData);\r
+ }\r
+ VkResult vkGetQueryPoolResults( VkDevice device, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, size_t dataSize, void* pData, VkDeviceSize stride, VkQueryResultFlags flags ) const\r
+ {\r
+ return ::vkGetQueryPoolResults( device, queryPool, firstQuery, queryCount, dataSize, pData, stride, flags);\r
+ }\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ VkResult vkGetRandROutputDisplayEXT( VkPhysicalDevice physicalDevice, Display* dpy, RROutput rrOutput, VkDisplayKHR* pDisplay ) const\r
+ {\r
+ return ::vkGetRandROutputDisplayEXT( physicalDevice, dpy, rrOutput, pDisplay);\r
+ }\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+ VkResult vkGetRefreshCycleDurationGOOGLE( VkDevice device, VkSwapchainKHR swapchain, VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties ) const\r
+ {\r
+ return ::vkGetRefreshCycleDurationGOOGLE( device, swapchain, pDisplayTimingProperties);\r
+ }\r
+ void vkGetRenderAreaGranularity( VkDevice device, VkRenderPass renderPass, VkExtent2D* pGranularity ) const\r
+ {\r
+ return ::vkGetRenderAreaGranularity( device, renderPass, pGranularity);\r
+ }\r
+ VkResult vkGetSemaphoreFdKHR( VkDevice device, const VkSemaphoreGetFdInfoKHR* pGetFdInfo, int* pFd ) const\r
+ {\r
+ return ::vkGetSemaphoreFdKHR( device, pGetFdInfo, pFd);\r
+ }\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkGetSemaphoreWin32HandleKHR( VkDevice device, const VkSemaphoreGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle ) const\r
+ {\r
+ return ::vkGetSemaphoreWin32HandleKHR( device, pGetWin32HandleInfo, pHandle);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ VkResult vkGetShaderInfoAMD( VkDevice device, VkPipeline pipeline, VkShaderStageFlagBits shaderStage, VkShaderInfoTypeAMD infoType, size_t* pInfoSize, void* pInfo ) const\r
+ {\r
+ return ::vkGetShaderInfoAMD( device, pipeline, shaderStage, infoType, pInfoSize, pInfo);\r
+ }\r
+ VkResult vkGetSwapchainCounterEXT( VkDevice device, VkSwapchainKHR swapchain, VkSurfaceCounterFlagBitsEXT counter, uint64_t* pCounterValue ) const\r
+ {\r
+ return ::vkGetSwapchainCounterEXT( device, swapchain, counter, pCounterValue);\r
+ }\r
+ VkResult vkGetSwapchainImagesKHR( VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages ) const\r
+ {\r
+ return ::vkGetSwapchainImagesKHR( device, swapchain, pSwapchainImageCount, pSwapchainImages);\r
+ }\r
+ VkResult vkGetSwapchainStatusKHR( VkDevice device, VkSwapchainKHR swapchain ) const\r
+ {\r
+ return ::vkGetSwapchainStatusKHR( device, swapchain);\r
+ }\r
+ VkResult vkGetValidationCacheDataEXT( VkDevice device, VkValidationCacheEXT validationCache, size_t* pDataSize, void* pData ) const\r
+ {\r
+ return ::vkGetValidationCacheDataEXT( device, validationCache, pDataSize, pData);\r
+ }\r
+ VkResult vkImportFenceFdKHR( VkDevice device, const VkImportFenceFdInfoKHR* pImportFenceFdInfo ) const\r
+ {\r
+ return ::vkImportFenceFdKHR( device, pImportFenceFdInfo);\r
+ }\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkImportFenceWin32HandleKHR( VkDevice device, const VkImportFenceWin32HandleInfoKHR* pImportFenceWin32HandleInfo ) const\r
+ {\r
+ return ::vkImportFenceWin32HandleKHR( device, pImportFenceWin32HandleInfo);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ VkResult vkImportSemaphoreFdKHR( VkDevice device, const VkImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo ) const\r
+ {\r
+ return ::vkImportSemaphoreFdKHR( device, pImportSemaphoreFdInfo);\r
+ }\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VkResult vkImportSemaphoreWin32HandleKHR( VkDevice device, const VkImportSemaphoreWin32HandleInfoKHR* pImportSemaphoreWin32HandleInfo ) const\r
+ {\r
+ return ::vkImportSemaphoreWin32HandleKHR( device, pImportSemaphoreWin32HandleInfo);\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ VkResult vkInvalidateMappedMemoryRanges( VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges ) const\r
+ {\r
+ return ::vkInvalidateMappedMemoryRanges( device, memoryRangeCount, pMemoryRanges);\r
+ }\r
+ VkResult vkMapMemory( VkDevice device, VkDeviceMemory memory, VkDeviceSize offset, VkDeviceSize size, VkMemoryMapFlags flags, void** ppData ) const\r
+ {\r
+ return ::vkMapMemory( device, memory, offset, size, flags, ppData);\r
+ }\r
+ VkResult vkMergePipelineCaches( VkDevice device, VkPipelineCache dstCache, uint32_t srcCacheCount, const VkPipelineCache* pSrcCaches ) const\r
+ {\r
+ return ::vkMergePipelineCaches( device, dstCache, srcCacheCount, pSrcCaches);\r
+ }\r
+ VkResult vkMergeValidationCachesEXT( VkDevice device, VkValidationCacheEXT dstCache, uint32_t srcCacheCount, const VkValidationCacheEXT* pSrcCaches ) const\r
+ {\r
+ return ::vkMergeValidationCachesEXT( device, dstCache, srcCacheCount, pSrcCaches);\r
+ }\r
+ void vkQueueBeginDebugUtilsLabelEXT( VkQueue queue, const VkDebugUtilsLabelEXT* pLabelInfo ) const\r
+ {\r
+ return ::vkQueueBeginDebugUtilsLabelEXT( queue, pLabelInfo);\r
+ }\r
+ VkResult vkQueueBindSparse( VkQueue queue, uint32_t bindInfoCount, const VkBindSparseInfo* pBindInfo, VkFence fence ) const\r
+ {\r
+ return ::vkQueueBindSparse( queue, bindInfoCount, pBindInfo, fence);\r
+ }\r
+ void vkQueueEndDebugUtilsLabelEXT( VkQueue queue ) const\r
+ {\r
+ return ::vkQueueEndDebugUtilsLabelEXT( queue);\r
+ }\r
+ void vkQueueInsertDebugUtilsLabelEXT( VkQueue queue, const VkDebugUtilsLabelEXT* pLabelInfo ) const\r
+ {\r
+ return ::vkQueueInsertDebugUtilsLabelEXT( queue, pLabelInfo);\r
+ }\r
+ VkResult vkQueuePresentKHR( VkQueue queue, const VkPresentInfoKHR* pPresentInfo ) const\r
+ {\r
+ return ::vkQueuePresentKHR( queue, pPresentInfo);\r
+ }\r
+ VkResult vkQueueSubmit( VkQueue queue, uint32_t submitCount, const VkSubmitInfo* pSubmits, VkFence fence ) const\r
+ {\r
+ return ::vkQueueSubmit( queue, submitCount, pSubmits, fence);\r
+ }\r
+ VkResult vkQueueWaitIdle( VkQueue queue ) const\r
+ {\r
+ return ::vkQueueWaitIdle( queue);\r
+ }\r
+ VkResult vkRegisterDeviceEventEXT( VkDevice device, const VkDeviceEventInfoEXT* pDeviceEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence ) const\r
+ {\r
+ return ::vkRegisterDeviceEventEXT( device, pDeviceEventInfo, pAllocator, pFence);\r
+ }\r
+ VkResult vkRegisterDisplayEventEXT( VkDevice device, VkDisplayKHR display, const VkDisplayEventInfoEXT* pDisplayEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence ) const\r
+ {\r
+ return ::vkRegisterDisplayEventEXT( device, display, pDisplayEventInfo, pAllocator, pFence);\r
+ }\r
+ VkResult vkRegisterObjectsNVX( VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectTableEntryNVX* const* ppObjectTableEntries, const uint32_t* pObjectIndices ) const\r
+ {\r
+ return ::vkRegisterObjectsNVX( device, objectTable, objectCount, ppObjectTableEntries, pObjectIndices);\r
+ }\r
+ VkResult vkReleaseDisplayEXT( VkPhysicalDevice physicalDevice, VkDisplayKHR display ) const\r
+ {\r
+ return ::vkReleaseDisplayEXT( physicalDevice, display);\r
+ }\r
+ VkResult vkResetCommandBuffer( VkCommandBuffer commandBuffer, VkCommandBufferResetFlags flags ) const\r
+ {\r
+ return ::vkResetCommandBuffer( commandBuffer, flags);\r
+ }\r
+ VkResult vkResetCommandPool( VkDevice device, VkCommandPool commandPool, VkCommandPoolResetFlags flags ) const\r
+ {\r
+ return ::vkResetCommandPool( device, commandPool, flags);\r
+ }\r
+ VkResult vkResetDescriptorPool( VkDevice device, VkDescriptorPool descriptorPool, VkDescriptorPoolResetFlags flags ) const\r
+ {\r
+ return ::vkResetDescriptorPool( device, descriptorPool, flags);\r
+ }\r
+ VkResult vkResetEvent( VkDevice device, VkEvent event ) const\r
+ {\r
+ return ::vkResetEvent( device, event);\r
+ }\r
+ VkResult vkResetFences( VkDevice device, uint32_t fenceCount, const VkFence* pFences ) const\r
+ {\r
+ return ::vkResetFences( device, fenceCount, pFences);\r
+ }\r
+ VkResult vkSetDebugUtilsObjectNameEXT( VkDevice device, const VkDebugUtilsObjectNameInfoEXT* pNameInfo ) const\r
+ {\r
+ return ::vkSetDebugUtilsObjectNameEXT( device, pNameInfo);\r
+ }\r
+ VkResult vkSetDebugUtilsObjectTagEXT( VkDevice device, const VkDebugUtilsObjectTagInfoEXT* pTagInfo ) const\r
+ {\r
+ return ::vkSetDebugUtilsObjectTagEXT( device, pTagInfo);\r
+ }\r
+ VkResult vkSetEvent( VkDevice device, VkEvent event ) const\r
+ {\r
+ return ::vkSetEvent( device, event);\r
+ }\r
+ void vkSetHdrMetadataEXT( VkDevice device, uint32_t swapchainCount, const VkSwapchainKHR* pSwapchains, const VkHdrMetadataEXT* pMetadata ) const\r
+ {\r
+ return ::vkSetHdrMetadataEXT( device, swapchainCount, pSwapchains, pMetadata);\r
+ }\r
+ void vkSubmitDebugUtilsMessageEXT( VkInstance instance, VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity, VkDebugUtilsMessageTypeFlagsEXT messageTypes, const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData ) const\r
+ {\r
+ return ::vkSubmitDebugUtilsMessageEXT( instance, messageSeverity, messageTypes, pCallbackData);\r
+ }\r
+ void vkTrimCommandPool( VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlags flags ) const\r
+ {\r
+ return ::vkTrimCommandPool( device, commandPool, flags);\r
+ }\r
+ void vkTrimCommandPoolKHR( VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlags flags ) const\r
+ {\r
+ return ::vkTrimCommandPoolKHR( device, commandPool, flags);\r
+ }\r
+ void vkUnmapMemory( VkDevice device, VkDeviceMemory memory ) const\r
+ {\r
+ return ::vkUnmapMemory( device, memory);\r
+ }\r
+ VkResult vkUnregisterObjectsNVX( VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectEntryTypeNVX* pObjectEntryTypes, const uint32_t* pObjectIndices ) const\r
+ {\r
+ return ::vkUnregisterObjectsNVX( device, objectTable, objectCount, pObjectEntryTypes, pObjectIndices);\r
+ }\r
+ void vkUpdateDescriptorSetWithTemplate( VkDevice device, VkDescriptorSet descriptorSet, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData ) const\r
+ {\r
+ return ::vkUpdateDescriptorSetWithTemplate( device, descriptorSet, descriptorUpdateTemplate, pData);\r
+ }\r
+ void vkUpdateDescriptorSetWithTemplateKHR( VkDevice device, VkDescriptorSet descriptorSet, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData ) const\r
+ {\r
+ return ::vkUpdateDescriptorSetWithTemplateKHR( device, descriptorSet, descriptorUpdateTemplate, pData);\r
+ }\r
+ void vkUpdateDescriptorSets( VkDevice device, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites, uint32_t descriptorCopyCount, const VkCopyDescriptorSet* pDescriptorCopies ) const\r
+ {\r
+ return ::vkUpdateDescriptorSets( device, descriptorWriteCount, pDescriptorWrites, descriptorCopyCount, pDescriptorCopies);\r
+ }\r
+ VkResult vkWaitForFences( VkDevice device, uint32_t fenceCount, const VkFence* pFences, VkBool32 waitAll, uint64_t timeout ) const\r
+ {\r
+ return ::vkWaitForFences( device, fenceCount, pFences, waitAll, timeout);\r
+ }\r
+};\r
+ using SampleMask = uint32_t;\r
+\r
+ using Bool32 = uint32_t;\r
+\r
+ using DeviceSize = uint64_t;\r
+\r
+ enum class FramebufferCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using FramebufferCreateFlags = Flags<FramebufferCreateFlagBits, VkFramebufferCreateFlags>;\r
+\r
+ enum class QueryPoolCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using QueryPoolCreateFlags = Flags<QueryPoolCreateFlagBits, VkQueryPoolCreateFlags>;\r
+\r
+ enum class RenderPassCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using RenderPassCreateFlags = Flags<RenderPassCreateFlagBits, VkRenderPassCreateFlags>;\r
+\r
+ enum class SamplerCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using SamplerCreateFlags = Flags<SamplerCreateFlagBits, VkSamplerCreateFlags>;\r
+\r
+ enum class PipelineLayoutCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineLayoutCreateFlags = Flags<PipelineLayoutCreateFlagBits, VkPipelineLayoutCreateFlags>;\r
+\r
+ enum class PipelineCacheCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineCacheCreateFlags = Flags<PipelineCacheCreateFlagBits, VkPipelineCacheCreateFlags>;\r
+\r
+ enum class PipelineDepthStencilStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineDepthStencilStateCreateFlags = Flags<PipelineDepthStencilStateCreateFlagBits, VkPipelineDepthStencilStateCreateFlags>;\r
+\r
+ enum class PipelineDynamicStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineDynamicStateCreateFlags = Flags<PipelineDynamicStateCreateFlagBits, VkPipelineDynamicStateCreateFlags>;\r
+\r
+ enum class PipelineColorBlendStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineColorBlendStateCreateFlags = Flags<PipelineColorBlendStateCreateFlagBits, VkPipelineColorBlendStateCreateFlags>;\r
+\r
+ enum class PipelineMultisampleStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineMultisampleStateCreateFlags = Flags<PipelineMultisampleStateCreateFlagBits, VkPipelineMultisampleStateCreateFlags>;\r
+\r
+ enum class PipelineRasterizationStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineRasterizationStateCreateFlags = Flags<PipelineRasterizationStateCreateFlagBits, VkPipelineRasterizationStateCreateFlags>;\r
+\r
+ enum class PipelineViewportStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineViewportStateCreateFlags = Flags<PipelineViewportStateCreateFlagBits, VkPipelineViewportStateCreateFlags>;\r
+\r
+ enum class PipelineTessellationStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineTessellationStateCreateFlags = Flags<PipelineTessellationStateCreateFlagBits, VkPipelineTessellationStateCreateFlags>;\r
+\r
+ enum class PipelineInputAssemblyStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineInputAssemblyStateCreateFlags = Flags<PipelineInputAssemblyStateCreateFlagBits, VkPipelineInputAssemblyStateCreateFlags>;\r
+\r
+ enum class PipelineVertexInputStateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineVertexInputStateCreateFlags = Flags<PipelineVertexInputStateCreateFlagBits, VkPipelineVertexInputStateCreateFlags>;\r
+\r
+ enum class PipelineShaderStageCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using PipelineShaderStageCreateFlags = Flags<PipelineShaderStageCreateFlagBits, VkPipelineShaderStageCreateFlags>;\r
+\r
+ enum class BufferViewCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using BufferViewCreateFlags = Flags<BufferViewCreateFlagBits, VkBufferViewCreateFlags>;\r
+\r
+ enum class InstanceCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using InstanceCreateFlags = Flags<InstanceCreateFlagBits, VkInstanceCreateFlags>;\r
+\r
+ enum class DeviceCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using DeviceCreateFlags = Flags<DeviceCreateFlagBits, VkDeviceCreateFlags>;\r
+\r
+ enum class ImageViewCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using ImageViewCreateFlags = Flags<ImageViewCreateFlagBits, VkImageViewCreateFlags>;\r
+\r
+ enum class SemaphoreCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using SemaphoreCreateFlags = Flags<SemaphoreCreateFlagBits, VkSemaphoreCreateFlags>;\r
+\r
+ enum class ShaderModuleCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using ShaderModuleCreateFlags = Flags<ShaderModuleCreateFlagBits, VkShaderModuleCreateFlags>;\r
+\r
+ enum class EventCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using EventCreateFlags = Flags<EventCreateFlagBits, VkEventCreateFlags>;\r
+\r
+ enum class MemoryMapFlagBits\r
+ {\r
+ };\r
+\r
+ using MemoryMapFlags = Flags<MemoryMapFlagBits, VkMemoryMapFlags>;\r
+\r
+ enum class DescriptorPoolResetFlagBits\r
+ {\r
+ };\r
+\r
+ using DescriptorPoolResetFlags = Flags<DescriptorPoolResetFlagBits, VkDescriptorPoolResetFlags>;\r
+\r
+ enum class DescriptorUpdateTemplateCreateFlagBits\r
+ {\r
+ };\r
+\r
+ using DescriptorUpdateTemplateCreateFlags = Flags<DescriptorUpdateTemplateCreateFlagBits, VkDescriptorUpdateTemplateCreateFlags>;\r
+\r
+ using DescriptorUpdateTemplateCreateFlagsKHR = DescriptorUpdateTemplateCreateFlags;\r
+\r
+ enum class DisplayModeCreateFlagBitsKHR\r
+ {\r
+ };\r
+\r
+ using DisplayModeCreateFlagsKHR = Flags<DisplayModeCreateFlagBitsKHR, VkDisplayModeCreateFlagsKHR>;\r
+\r
+ enum class DisplaySurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+\r
+ using DisplaySurfaceCreateFlagsKHR = Flags<DisplaySurfaceCreateFlagBitsKHR, VkDisplaySurfaceCreateFlagsKHR>;\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ enum class AndroidSurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ using AndroidSurfaceCreateFlagsKHR = Flags<AndroidSurfaceCreateFlagBitsKHR, VkAndroidSurfaceCreateFlagsKHR>;\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ enum class MirSurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ using MirSurfaceCreateFlagsKHR = Flags<MirSurfaceCreateFlagBitsKHR, VkMirSurfaceCreateFlagsKHR>;\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ enum class ViSurfaceCreateFlagBitsNN\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ using ViSurfaceCreateFlagsNN = Flags<ViSurfaceCreateFlagBitsNN, VkViSurfaceCreateFlagsNN>;\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ enum class WaylandSurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ using WaylandSurfaceCreateFlagsKHR = Flags<WaylandSurfaceCreateFlagBitsKHR, VkWaylandSurfaceCreateFlagsKHR>;\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ enum class Win32SurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ using Win32SurfaceCreateFlagsKHR = Flags<Win32SurfaceCreateFlagBitsKHR, VkWin32SurfaceCreateFlagsKHR>;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ enum class XlibSurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ using XlibSurfaceCreateFlagsKHR = Flags<XlibSurfaceCreateFlagBitsKHR, VkXlibSurfaceCreateFlagsKHR>;\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ enum class XcbSurfaceCreateFlagBitsKHR\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ using XcbSurfaceCreateFlagsKHR = Flags<XcbSurfaceCreateFlagBitsKHR, VkXcbSurfaceCreateFlagsKHR>;\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ enum class IOSSurfaceCreateFlagBitsMVK\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ using IOSSurfaceCreateFlagsMVK = Flags<IOSSurfaceCreateFlagBitsMVK, VkIOSSurfaceCreateFlagsMVK>;\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ enum class MacOSSurfaceCreateFlagBitsMVK\r
+ {\r
+ };\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ using MacOSSurfaceCreateFlagsMVK = Flags<MacOSSurfaceCreateFlagBitsMVK, VkMacOSSurfaceCreateFlagsMVK>;\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+ enum class CommandPoolTrimFlagBits\r
+ {\r
+ };\r
+\r
+ using CommandPoolTrimFlags = Flags<CommandPoolTrimFlagBits, VkCommandPoolTrimFlags>;\r
+\r
+ using CommandPoolTrimFlagsKHR = CommandPoolTrimFlags;\r
+\r
+ enum class PipelineViewportSwizzleStateCreateFlagBitsNV\r
+ {\r
+ };\r
+\r
+ using PipelineViewportSwizzleStateCreateFlagsNV = Flags<PipelineViewportSwizzleStateCreateFlagBitsNV, VkPipelineViewportSwizzleStateCreateFlagsNV>;\r
+\r
+ enum class PipelineDiscardRectangleStateCreateFlagBitsEXT\r
+ {\r
+ };\r
+\r
+ using PipelineDiscardRectangleStateCreateFlagsEXT = Flags<PipelineDiscardRectangleStateCreateFlagBitsEXT, VkPipelineDiscardRectangleStateCreateFlagsEXT>;\r
+\r
+ enum class PipelineCoverageToColorStateCreateFlagBitsNV\r
+ {\r
+ };\r
+\r
+ using PipelineCoverageToColorStateCreateFlagsNV = Flags<PipelineCoverageToColorStateCreateFlagBitsNV, VkPipelineCoverageToColorStateCreateFlagsNV>;\r
+\r
+ enum class PipelineCoverageModulationStateCreateFlagBitsNV\r
+ {\r
+ };\r
+\r
+ using PipelineCoverageModulationStateCreateFlagsNV = Flags<PipelineCoverageModulationStateCreateFlagBitsNV, VkPipelineCoverageModulationStateCreateFlagsNV>;\r
+\r
+ enum class ValidationCacheCreateFlagBitsEXT\r
+ {\r
+ };\r
+\r
+ using ValidationCacheCreateFlagsEXT = Flags<ValidationCacheCreateFlagBitsEXT, VkValidationCacheCreateFlagsEXT>;\r
+\r
+ enum class DebugUtilsMessengerCreateFlagBitsEXT\r
+ {\r
+ };\r
+\r
+ using DebugUtilsMessengerCreateFlagsEXT = Flags<DebugUtilsMessengerCreateFlagBitsEXT, VkDebugUtilsMessengerCreateFlagsEXT>;\r
+\r
+ enum class DebugUtilsMessengerCallbackDataFlagBitsEXT\r
+ {\r
+ };\r
+\r
+ using DebugUtilsMessengerCallbackDataFlagsEXT = Flags<DebugUtilsMessengerCallbackDataFlagBitsEXT, VkDebugUtilsMessengerCallbackDataFlagsEXT>;\r
+\r
+ enum class PipelineRasterizationConservativeStateCreateFlagBitsEXT\r
+ {\r
+ };\r
+\r
+ using PipelineRasterizationConservativeStateCreateFlagsEXT = Flags<PipelineRasterizationConservativeStateCreateFlagBitsEXT, VkPipelineRasterizationConservativeStateCreateFlagsEXT>;\r
+\r
+ class DeviceMemory\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DeviceMemory()\r
+ : m_deviceMemory(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DeviceMemory( std::nullptr_t )\r
+ : m_deviceMemory(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DeviceMemory( VkDeviceMemory deviceMemory )\r
+ : m_deviceMemory( deviceMemory )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DeviceMemory & operator=(VkDeviceMemory deviceMemory)\r
+ {\r
+ m_deviceMemory = deviceMemory;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DeviceMemory & operator=( std::nullptr_t )\r
+ {\r
+ m_deviceMemory = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DeviceMemory const & rhs ) const\r
+ {\r
+ return m_deviceMemory == rhs.m_deviceMemory;\r
+ }\r
+\r
+ bool operator!=(DeviceMemory const & rhs ) const\r
+ {\r
+ return m_deviceMemory != rhs.m_deviceMemory;\r
+ }\r
+\r
+ bool operator<(DeviceMemory const & rhs ) const\r
+ {\r
+ return m_deviceMemory < rhs.m_deviceMemory;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDeviceMemory() const\r
+ {\r
+ return m_deviceMemory;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_deviceMemory != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_deviceMemory == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDeviceMemory m_deviceMemory;\r
+ };\r
+\r
+ static_assert( sizeof( DeviceMemory ) == sizeof( VkDeviceMemory ), "handle and wrapper have different size!" );\r
+\r
+ class CommandPool\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR CommandPool()\r
+ : m_commandPool(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR CommandPool( std::nullptr_t )\r
+ : m_commandPool(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT CommandPool( VkCommandPool commandPool )\r
+ : m_commandPool( commandPool )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ CommandPool & operator=(VkCommandPool commandPool)\r
+ {\r
+ m_commandPool = commandPool;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ CommandPool & operator=( std::nullptr_t )\r
+ {\r
+ m_commandPool = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( CommandPool const & rhs ) const\r
+ {\r
+ return m_commandPool == rhs.m_commandPool;\r
+ }\r
+\r
+ bool operator!=(CommandPool const & rhs ) const\r
+ {\r
+ return m_commandPool != rhs.m_commandPool;\r
+ }\r
+\r
+ bool operator<(CommandPool const & rhs ) const\r
+ {\r
+ return m_commandPool < rhs.m_commandPool;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkCommandPool() const\r
+ {\r
+ return m_commandPool;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_commandPool != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_commandPool == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkCommandPool m_commandPool;\r
+ };\r
+\r
+ static_assert( sizeof( CommandPool ) == sizeof( VkCommandPool ), "handle and wrapper have different size!" );\r
+\r
+ class Buffer\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Buffer()\r
+ : m_buffer(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Buffer( std::nullptr_t )\r
+ : m_buffer(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Buffer( VkBuffer buffer )\r
+ : m_buffer( buffer )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Buffer & operator=(VkBuffer buffer)\r
+ {\r
+ m_buffer = buffer;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Buffer & operator=( std::nullptr_t )\r
+ {\r
+ m_buffer = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Buffer const & rhs ) const\r
+ {\r
+ return m_buffer == rhs.m_buffer;\r
+ }\r
+\r
+ bool operator!=(Buffer const & rhs ) const\r
+ {\r
+ return m_buffer != rhs.m_buffer;\r
+ }\r
+\r
+ bool operator<(Buffer const & rhs ) const\r
+ {\r
+ return m_buffer < rhs.m_buffer;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkBuffer() const\r
+ {\r
+ return m_buffer;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_buffer != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_buffer == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkBuffer m_buffer;\r
+ };\r
+\r
+ static_assert( sizeof( Buffer ) == sizeof( VkBuffer ), "handle and wrapper have different size!" );\r
+\r
+ class BufferView\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR BufferView()\r
+ : m_bufferView(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR BufferView( std::nullptr_t )\r
+ : m_bufferView(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT BufferView( VkBufferView bufferView )\r
+ : m_bufferView( bufferView )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ BufferView & operator=(VkBufferView bufferView)\r
+ {\r
+ m_bufferView = bufferView;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ BufferView & operator=( std::nullptr_t )\r
+ {\r
+ m_bufferView = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( BufferView const & rhs ) const\r
+ {\r
+ return m_bufferView == rhs.m_bufferView;\r
+ }\r
+\r
+ bool operator!=(BufferView const & rhs ) const\r
+ {\r
+ return m_bufferView != rhs.m_bufferView;\r
+ }\r
+\r
+ bool operator<(BufferView const & rhs ) const\r
+ {\r
+ return m_bufferView < rhs.m_bufferView;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkBufferView() const\r
+ {\r
+ return m_bufferView;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_bufferView != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_bufferView == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkBufferView m_bufferView;\r
+ };\r
+\r
+ static_assert( sizeof( BufferView ) == sizeof( VkBufferView ), "handle and wrapper have different size!" );\r
+\r
+ class Image\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Image()\r
+ : m_image(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Image( std::nullptr_t )\r
+ : m_image(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Image( VkImage image )\r
+ : m_image( image )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Image & operator=(VkImage image)\r
+ {\r
+ m_image = image;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Image & operator=( std::nullptr_t )\r
+ {\r
+ m_image = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Image const & rhs ) const\r
+ {\r
+ return m_image == rhs.m_image;\r
+ }\r
+\r
+ bool operator!=(Image const & rhs ) const\r
+ {\r
+ return m_image != rhs.m_image;\r
+ }\r
+\r
+ bool operator<(Image const & rhs ) const\r
+ {\r
+ return m_image < rhs.m_image;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkImage() const\r
+ {\r
+ return m_image;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_image != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_image == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkImage m_image;\r
+ };\r
+\r
+ static_assert( sizeof( Image ) == sizeof( VkImage ), "handle and wrapper have different size!" );\r
+\r
+ class ImageView\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR ImageView()\r
+ : m_imageView(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR ImageView( std::nullptr_t )\r
+ : m_imageView(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT ImageView( VkImageView imageView )\r
+ : m_imageView( imageView )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ ImageView & operator=(VkImageView imageView)\r
+ {\r
+ m_imageView = imageView;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ ImageView & operator=( std::nullptr_t )\r
+ {\r
+ m_imageView = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( ImageView const & rhs ) const\r
+ {\r
+ return m_imageView == rhs.m_imageView;\r
+ }\r
+\r
+ bool operator!=(ImageView const & rhs ) const\r
+ {\r
+ return m_imageView != rhs.m_imageView;\r
+ }\r
+\r
+ bool operator<(ImageView const & rhs ) const\r
+ {\r
+ return m_imageView < rhs.m_imageView;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkImageView() const\r
+ {\r
+ return m_imageView;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_imageView != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_imageView == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkImageView m_imageView;\r
+ };\r
+\r
+ static_assert( sizeof( ImageView ) == sizeof( VkImageView ), "handle and wrapper have different size!" );\r
+\r
+ class ShaderModule\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR ShaderModule()\r
+ : m_shaderModule(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR ShaderModule( std::nullptr_t )\r
+ : m_shaderModule(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT ShaderModule( VkShaderModule shaderModule )\r
+ : m_shaderModule( shaderModule )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ ShaderModule & operator=(VkShaderModule shaderModule)\r
+ {\r
+ m_shaderModule = shaderModule;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ ShaderModule & operator=( std::nullptr_t )\r
+ {\r
+ m_shaderModule = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( ShaderModule const & rhs ) const\r
+ {\r
+ return m_shaderModule == rhs.m_shaderModule;\r
+ }\r
+\r
+ bool operator!=(ShaderModule const & rhs ) const\r
+ {\r
+ return m_shaderModule != rhs.m_shaderModule;\r
+ }\r
+\r
+ bool operator<(ShaderModule const & rhs ) const\r
+ {\r
+ return m_shaderModule < rhs.m_shaderModule;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkShaderModule() const\r
+ {\r
+ return m_shaderModule;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_shaderModule != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_shaderModule == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkShaderModule m_shaderModule;\r
+ };\r
+\r
+ static_assert( sizeof( ShaderModule ) == sizeof( VkShaderModule ), "handle and wrapper have different size!" );\r
+\r
+ class Pipeline\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Pipeline()\r
+ : m_pipeline(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Pipeline( std::nullptr_t )\r
+ : m_pipeline(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Pipeline( VkPipeline pipeline )\r
+ : m_pipeline( pipeline )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Pipeline & operator=(VkPipeline pipeline)\r
+ {\r
+ m_pipeline = pipeline;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Pipeline & operator=( std::nullptr_t )\r
+ {\r
+ m_pipeline = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Pipeline const & rhs ) const\r
+ {\r
+ return m_pipeline == rhs.m_pipeline;\r
+ }\r
+\r
+ bool operator!=(Pipeline const & rhs ) const\r
+ {\r
+ return m_pipeline != rhs.m_pipeline;\r
+ }\r
+\r
+ bool operator<(Pipeline const & rhs ) const\r
+ {\r
+ return m_pipeline < rhs.m_pipeline;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkPipeline() const\r
+ {\r
+ return m_pipeline;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_pipeline != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_pipeline == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkPipeline m_pipeline;\r
+ };\r
+\r
+ static_assert( sizeof( Pipeline ) == sizeof( VkPipeline ), "handle and wrapper have different size!" );\r
+\r
+ class PipelineLayout\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR PipelineLayout()\r
+ : m_pipelineLayout(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR PipelineLayout( std::nullptr_t )\r
+ : m_pipelineLayout(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT PipelineLayout( VkPipelineLayout pipelineLayout )\r
+ : m_pipelineLayout( pipelineLayout )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ PipelineLayout & operator=(VkPipelineLayout pipelineLayout)\r
+ {\r
+ m_pipelineLayout = pipelineLayout;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ PipelineLayout & operator=( std::nullptr_t )\r
+ {\r
+ m_pipelineLayout = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( PipelineLayout const & rhs ) const\r
+ {\r
+ return m_pipelineLayout == rhs.m_pipelineLayout;\r
+ }\r
+\r
+ bool operator!=(PipelineLayout const & rhs ) const\r
+ {\r
+ return m_pipelineLayout != rhs.m_pipelineLayout;\r
+ }\r
+\r
+ bool operator<(PipelineLayout const & rhs ) const\r
+ {\r
+ return m_pipelineLayout < rhs.m_pipelineLayout;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkPipelineLayout() const\r
+ {\r
+ return m_pipelineLayout;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_pipelineLayout != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_pipelineLayout == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkPipelineLayout m_pipelineLayout;\r
+ };\r
+\r
+ static_assert( sizeof( PipelineLayout ) == sizeof( VkPipelineLayout ), "handle and wrapper have different size!" );\r
+\r
+ class Sampler\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Sampler()\r
+ : m_sampler(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Sampler( std::nullptr_t )\r
+ : m_sampler(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Sampler( VkSampler sampler )\r
+ : m_sampler( sampler )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Sampler & operator=(VkSampler sampler)\r
+ {\r
+ m_sampler = sampler;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Sampler & operator=( std::nullptr_t )\r
+ {\r
+ m_sampler = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Sampler const & rhs ) const\r
+ {\r
+ return m_sampler == rhs.m_sampler;\r
+ }\r
+\r
+ bool operator!=(Sampler const & rhs ) const\r
+ {\r
+ return m_sampler != rhs.m_sampler;\r
+ }\r
+\r
+ bool operator<(Sampler const & rhs ) const\r
+ {\r
+ return m_sampler < rhs.m_sampler;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkSampler() const\r
+ {\r
+ return m_sampler;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_sampler != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_sampler == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkSampler m_sampler;\r
+ };\r
+\r
+ static_assert( sizeof( Sampler ) == sizeof( VkSampler ), "handle and wrapper have different size!" );\r
+\r
+ class DescriptorSet\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DescriptorSet()\r
+ : m_descriptorSet(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DescriptorSet( std::nullptr_t )\r
+ : m_descriptorSet(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DescriptorSet( VkDescriptorSet descriptorSet )\r
+ : m_descriptorSet( descriptorSet )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DescriptorSet & operator=(VkDescriptorSet descriptorSet)\r
+ {\r
+ m_descriptorSet = descriptorSet;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DescriptorSet & operator=( std::nullptr_t )\r
+ {\r
+ m_descriptorSet = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DescriptorSet const & rhs ) const\r
+ {\r
+ return m_descriptorSet == rhs.m_descriptorSet;\r
+ }\r
+\r
+ bool operator!=(DescriptorSet const & rhs ) const\r
+ {\r
+ return m_descriptorSet != rhs.m_descriptorSet;\r
+ }\r
+\r
+ bool operator<(DescriptorSet const & rhs ) const\r
+ {\r
+ return m_descriptorSet < rhs.m_descriptorSet;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDescriptorSet() const\r
+ {\r
+ return m_descriptorSet;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_descriptorSet != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_descriptorSet == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDescriptorSet m_descriptorSet;\r
+ };\r
+\r
+ static_assert( sizeof( DescriptorSet ) == sizeof( VkDescriptorSet ), "handle and wrapper have different size!" );\r
+\r
+ class DescriptorSetLayout\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DescriptorSetLayout()\r
+ : m_descriptorSetLayout(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DescriptorSetLayout( std::nullptr_t )\r
+ : m_descriptorSetLayout(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DescriptorSetLayout( VkDescriptorSetLayout descriptorSetLayout )\r
+ : m_descriptorSetLayout( descriptorSetLayout )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DescriptorSetLayout & operator=(VkDescriptorSetLayout descriptorSetLayout)\r
+ {\r
+ m_descriptorSetLayout = descriptorSetLayout;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DescriptorSetLayout & operator=( std::nullptr_t )\r
+ {\r
+ m_descriptorSetLayout = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DescriptorSetLayout const & rhs ) const\r
+ {\r
+ return m_descriptorSetLayout == rhs.m_descriptorSetLayout;\r
+ }\r
+\r
+ bool operator!=(DescriptorSetLayout const & rhs ) const\r
+ {\r
+ return m_descriptorSetLayout != rhs.m_descriptorSetLayout;\r
+ }\r
+\r
+ bool operator<(DescriptorSetLayout const & rhs ) const\r
+ {\r
+ return m_descriptorSetLayout < rhs.m_descriptorSetLayout;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDescriptorSetLayout() const\r
+ {\r
+ return m_descriptorSetLayout;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_descriptorSetLayout != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_descriptorSetLayout == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDescriptorSetLayout m_descriptorSetLayout;\r
+ };\r
+\r
+ static_assert( sizeof( DescriptorSetLayout ) == sizeof( VkDescriptorSetLayout ), "handle and wrapper have different size!" );\r
+\r
+ class DescriptorPool\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DescriptorPool()\r
+ : m_descriptorPool(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DescriptorPool( std::nullptr_t )\r
+ : m_descriptorPool(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DescriptorPool( VkDescriptorPool descriptorPool )\r
+ : m_descriptorPool( descriptorPool )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DescriptorPool & operator=(VkDescriptorPool descriptorPool)\r
+ {\r
+ m_descriptorPool = descriptorPool;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DescriptorPool & operator=( std::nullptr_t )\r
+ {\r
+ m_descriptorPool = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DescriptorPool const & rhs ) const\r
+ {\r
+ return m_descriptorPool == rhs.m_descriptorPool;\r
+ }\r
+\r
+ bool operator!=(DescriptorPool const & rhs ) const\r
+ {\r
+ return m_descriptorPool != rhs.m_descriptorPool;\r
+ }\r
+\r
+ bool operator<(DescriptorPool const & rhs ) const\r
+ {\r
+ return m_descriptorPool < rhs.m_descriptorPool;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDescriptorPool() const\r
+ {\r
+ return m_descriptorPool;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_descriptorPool != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_descriptorPool == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDescriptorPool m_descriptorPool;\r
+ };\r
+\r
+ static_assert( sizeof( DescriptorPool ) == sizeof( VkDescriptorPool ), "handle and wrapper have different size!" );\r
+\r
+ class Fence\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Fence()\r
+ : m_fence(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Fence( std::nullptr_t )\r
+ : m_fence(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Fence( VkFence fence )\r
+ : m_fence( fence )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Fence & operator=(VkFence fence)\r
+ {\r
+ m_fence = fence;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Fence & operator=( std::nullptr_t )\r
+ {\r
+ m_fence = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Fence const & rhs ) const\r
+ {\r
+ return m_fence == rhs.m_fence;\r
+ }\r
+\r
+ bool operator!=(Fence const & rhs ) const\r
+ {\r
+ return m_fence != rhs.m_fence;\r
+ }\r
+\r
+ bool operator<(Fence const & rhs ) const\r
+ {\r
+ return m_fence < rhs.m_fence;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkFence() const\r
+ {\r
+ return m_fence;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_fence != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_fence == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkFence m_fence;\r
+ };\r
+\r
+ static_assert( sizeof( Fence ) == sizeof( VkFence ), "handle and wrapper have different size!" );\r
+\r
+ class Semaphore\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Semaphore()\r
+ : m_semaphore(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Semaphore( std::nullptr_t )\r
+ : m_semaphore(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Semaphore( VkSemaphore semaphore )\r
+ : m_semaphore( semaphore )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Semaphore & operator=(VkSemaphore semaphore)\r
+ {\r
+ m_semaphore = semaphore;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Semaphore & operator=( std::nullptr_t )\r
+ {\r
+ m_semaphore = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Semaphore const & rhs ) const\r
+ {\r
+ return m_semaphore == rhs.m_semaphore;\r
+ }\r
+\r
+ bool operator!=(Semaphore const & rhs ) const\r
+ {\r
+ return m_semaphore != rhs.m_semaphore;\r
+ }\r
+\r
+ bool operator<(Semaphore const & rhs ) const\r
+ {\r
+ return m_semaphore < rhs.m_semaphore;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkSemaphore() const\r
+ {\r
+ return m_semaphore;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_semaphore != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_semaphore == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkSemaphore m_semaphore;\r
+ };\r
+\r
+ static_assert( sizeof( Semaphore ) == sizeof( VkSemaphore ), "handle and wrapper have different size!" );\r
+\r
+ class Event\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Event()\r
+ : m_event(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Event( std::nullptr_t )\r
+ : m_event(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Event( VkEvent event )\r
+ : m_event( event )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Event & operator=(VkEvent event)\r
+ {\r
+ m_event = event;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Event & operator=( std::nullptr_t )\r
+ {\r
+ m_event = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Event const & rhs ) const\r
+ {\r
+ return m_event == rhs.m_event;\r
+ }\r
+\r
+ bool operator!=(Event const & rhs ) const\r
+ {\r
+ return m_event != rhs.m_event;\r
+ }\r
+\r
+ bool operator<(Event const & rhs ) const\r
+ {\r
+ return m_event < rhs.m_event;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkEvent() const\r
+ {\r
+ return m_event;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_event != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_event == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkEvent m_event;\r
+ };\r
+\r
+ static_assert( sizeof( Event ) == sizeof( VkEvent ), "handle and wrapper have different size!" );\r
+\r
+ class QueryPool\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR QueryPool()\r
+ : m_queryPool(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR QueryPool( std::nullptr_t )\r
+ : m_queryPool(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT QueryPool( VkQueryPool queryPool )\r
+ : m_queryPool( queryPool )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ QueryPool & operator=(VkQueryPool queryPool)\r
+ {\r
+ m_queryPool = queryPool;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ QueryPool & operator=( std::nullptr_t )\r
+ {\r
+ m_queryPool = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( QueryPool const & rhs ) const\r
+ {\r
+ return m_queryPool == rhs.m_queryPool;\r
+ }\r
+\r
+ bool operator!=(QueryPool const & rhs ) const\r
+ {\r
+ return m_queryPool != rhs.m_queryPool;\r
+ }\r
+\r
+ bool operator<(QueryPool const & rhs ) const\r
+ {\r
+ return m_queryPool < rhs.m_queryPool;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkQueryPool() const\r
+ {\r
+ return m_queryPool;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_queryPool != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_queryPool == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkQueryPool m_queryPool;\r
+ };\r
+\r
+ static_assert( sizeof( QueryPool ) == sizeof( VkQueryPool ), "handle and wrapper have different size!" );\r
+\r
+ class Framebuffer\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Framebuffer()\r
+ : m_framebuffer(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Framebuffer( std::nullptr_t )\r
+ : m_framebuffer(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Framebuffer( VkFramebuffer framebuffer )\r
+ : m_framebuffer( framebuffer )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Framebuffer & operator=(VkFramebuffer framebuffer)\r
+ {\r
+ m_framebuffer = framebuffer;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Framebuffer & operator=( std::nullptr_t )\r
+ {\r
+ m_framebuffer = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Framebuffer const & rhs ) const\r
+ {\r
+ return m_framebuffer == rhs.m_framebuffer;\r
+ }\r
+\r
+ bool operator!=(Framebuffer const & rhs ) const\r
+ {\r
+ return m_framebuffer != rhs.m_framebuffer;\r
+ }\r
+\r
+ bool operator<(Framebuffer const & rhs ) const\r
+ {\r
+ return m_framebuffer < rhs.m_framebuffer;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkFramebuffer() const\r
+ {\r
+ return m_framebuffer;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_framebuffer != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_framebuffer == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkFramebuffer m_framebuffer;\r
+ };\r
+\r
+ static_assert( sizeof( Framebuffer ) == sizeof( VkFramebuffer ), "handle and wrapper have different size!" );\r
+\r
+ class RenderPass\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR RenderPass()\r
+ : m_renderPass(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR RenderPass( std::nullptr_t )\r
+ : m_renderPass(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT RenderPass( VkRenderPass renderPass )\r
+ : m_renderPass( renderPass )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ RenderPass & operator=(VkRenderPass renderPass)\r
+ {\r
+ m_renderPass = renderPass;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ RenderPass & operator=( std::nullptr_t )\r
+ {\r
+ m_renderPass = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( RenderPass const & rhs ) const\r
+ {\r
+ return m_renderPass == rhs.m_renderPass;\r
+ }\r
+\r
+ bool operator!=(RenderPass const & rhs ) const\r
+ {\r
+ return m_renderPass != rhs.m_renderPass;\r
+ }\r
+\r
+ bool operator<(RenderPass const & rhs ) const\r
+ {\r
+ return m_renderPass < rhs.m_renderPass;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkRenderPass() const\r
+ {\r
+ return m_renderPass;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_renderPass != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_renderPass == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkRenderPass m_renderPass;\r
+ };\r
+\r
+ static_assert( sizeof( RenderPass ) == sizeof( VkRenderPass ), "handle and wrapper have different size!" );\r
+\r
+ class PipelineCache\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR PipelineCache()\r
+ : m_pipelineCache(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR PipelineCache( std::nullptr_t )\r
+ : m_pipelineCache(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT PipelineCache( VkPipelineCache pipelineCache )\r
+ : m_pipelineCache( pipelineCache )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ PipelineCache & operator=(VkPipelineCache pipelineCache)\r
+ {\r
+ m_pipelineCache = pipelineCache;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ PipelineCache & operator=( std::nullptr_t )\r
+ {\r
+ m_pipelineCache = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( PipelineCache const & rhs ) const\r
+ {\r
+ return m_pipelineCache == rhs.m_pipelineCache;\r
+ }\r
+\r
+ bool operator!=(PipelineCache const & rhs ) const\r
+ {\r
+ return m_pipelineCache != rhs.m_pipelineCache;\r
+ }\r
+\r
+ bool operator<(PipelineCache const & rhs ) const\r
+ {\r
+ return m_pipelineCache < rhs.m_pipelineCache;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkPipelineCache() const\r
+ {\r
+ return m_pipelineCache;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_pipelineCache != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_pipelineCache == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkPipelineCache m_pipelineCache;\r
+ };\r
+\r
+ static_assert( sizeof( PipelineCache ) == sizeof( VkPipelineCache ), "handle and wrapper have different size!" );\r
+\r
+ class ObjectTableNVX\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR ObjectTableNVX()\r
+ : m_objectTableNVX(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR ObjectTableNVX( std::nullptr_t )\r
+ : m_objectTableNVX(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT ObjectTableNVX( VkObjectTableNVX objectTableNVX )\r
+ : m_objectTableNVX( objectTableNVX )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ ObjectTableNVX & operator=(VkObjectTableNVX objectTableNVX)\r
+ {\r
+ m_objectTableNVX = objectTableNVX;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ ObjectTableNVX & operator=( std::nullptr_t )\r
+ {\r
+ m_objectTableNVX = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( ObjectTableNVX const & rhs ) const\r
+ {\r
+ return m_objectTableNVX == rhs.m_objectTableNVX;\r
+ }\r
+\r
+ bool operator!=(ObjectTableNVX const & rhs ) const\r
+ {\r
+ return m_objectTableNVX != rhs.m_objectTableNVX;\r
+ }\r
+\r
+ bool operator<(ObjectTableNVX const & rhs ) const\r
+ {\r
+ return m_objectTableNVX < rhs.m_objectTableNVX;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkObjectTableNVX() const\r
+ {\r
+ return m_objectTableNVX;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_objectTableNVX != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_objectTableNVX == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkObjectTableNVX m_objectTableNVX;\r
+ };\r
+\r
+ static_assert( sizeof( ObjectTableNVX ) == sizeof( VkObjectTableNVX ), "handle and wrapper have different size!" );\r
+\r
+ class IndirectCommandsLayoutNVX\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR IndirectCommandsLayoutNVX()\r
+ : m_indirectCommandsLayoutNVX(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR IndirectCommandsLayoutNVX( std::nullptr_t )\r
+ : m_indirectCommandsLayoutNVX(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT IndirectCommandsLayoutNVX( VkIndirectCommandsLayoutNVX indirectCommandsLayoutNVX )\r
+ : m_indirectCommandsLayoutNVX( indirectCommandsLayoutNVX )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ IndirectCommandsLayoutNVX & operator=(VkIndirectCommandsLayoutNVX indirectCommandsLayoutNVX)\r
+ {\r
+ m_indirectCommandsLayoutNVX = indirectCommandsLayoutNVX;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ IndirectCommandsLayoutNVX & operator=( std::nullptr_t )\r
+ {\r
+ m_indirectCommandsLayoutNVX = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( IndirectCommandsLayoutNVX const & rhs ) const\r
+ {\r
+ return m_indirectCommandsLayoutNVX == rhs.m_indirectCommandsLayoutNVX;\r
+ }\r
+\r
+ bool operator!=(IndirectCommandsLayoutNVX const & rhs ) const\r
+ {\r
+ return m_indirectCommandsLayoutNVX != rhs.m_indirectCommandsLayoutNVX;\r
+ }\r
+\r
+ bool operator<(IndirectCommandsLayoutNVX const & rhs ) const\r
+ {\r
+ return m_indirectCommandsLayoutNVX < rhs.m_indirectCommandsLayoutNVX;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkIndirectCommandsLayoutNVX() const\r
+ {\r
+ return m_indirectCommandsLayoutNVX;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_indirectCommandsLayoutNVX != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_indirectCommandsLayoutNVX == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkIndirectCommandsLayoutNVX m_indirectCommandsLayoutNVX;\r
+ };\r
+\r
+ static_assert( sizeof( IndirectCommandsLayoutNVX ) == sizeof( VkIndirectCommandsLayoutNVX ), "handle and wrapper have different size!" );\r
+\r
+ class DescriptorUpdateTemplate\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DescriptorUpdateTemplate()\r
+ : m_descriptorUpdateTemplate(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DescriptorUpdateTemplate( std::nullptr_t )\r
+ : m_descriptorUpdateTemplate(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DescriptorUpdateTemplate( VkDescriptorUpdateTemplate descriptorUpdateTemplate )\r
+ : m_descriptorUpdateTemplate( descriptorUpdateTemplate )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DescriptorUpdateTemplate & operator=(VkDescriptorUpdateTemplate descriptorUpdateTemplate)\r
+ {\r
+ m_descriptorUpdateTemplate = descriptorUpdateTemplate;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DescriptorUpdateTemplate & operator=( std::nullptr_t )\r
+ {\r
+ m_descriptorUpdateTemplate = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DescriptorUpdateTemplate const & rhs ) const\r
+ {\r
+ return m_descriptorUpdateTemplate == rhs.m_descriptorUpdateTemplate;\r
+ }\r
+\r
+ bool operator!=(DescriptorUpdateTemplate const & rhs ) const\r
+ {\r
+ return m_descriptorUpdateTemplate != rhs.m_descriptorUpdateTemplate;\r
+ }\r
+\r
+ bool operator<(DescriptorUpdateTemplate const & rhs ) const\r
+ {\r
+ return m_descriptorUpdateTemplate < rhs.m_descriptorUpdateTemplate;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDescriptorUpdateTemplate() const\r
+ {\r
+ return m_descriptorUpdateTemplate;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_descriptorUpdateTemplate != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_descriptorUpdateTemplate == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDescriptorUpdateTemplate m_descriptorUpdateTemplate;\r
+ };\r
+\r
+ static_assert( sizeof( DescriptorUpdateTemplate ) == sizeof( VkDescriptorUpdateTemplate ), "handle and wrapper have different size!" );\r
+\r
+ using DescriptorUpdateTemplateKHR = DescriptorUpdateTemplate;\r
+\r
+ class SamplerYcbcrConversion\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR SamplerYcbcrConversion()\r
+ : m_samplerYcbcrConversion(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR SamplerYcbcrConversion( std::nullptr_t )\r
+ : m_samplerYcbcrConversion(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT SamplerYcbcrConversion( VkSamplerYcbcrConversion samplerYcbcrConversion )\r
+ : m_samplerYcbcrConversion( samplerYcbcrConversion )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ SamplerYcbcrConversion & operator=(VkSamplerYcbcrConversion samplerYcbcrConversion)\r
+ {\r
+ m_samplerYcbcrConversion = samplerYcbcrConversion;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ SamplerYcbcrConversion & operator=( std::nullptr_t )\r
+ {\r
+ m_samplerYcbcrConversion = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( SamplerYcbcrConversion const & rhs ) const\r
+ {\r
+ return m_samplerYcbcrConversion == rhs.m_samplerYcbcrConversion;\r
+ }\r
+\r
+ bool operator!=(SamplerYcbcrConversion const & rhs ) const\r
+ {\r
+ return m_samplerYcbcrConversion != rhs.m_samplerYcbcrConversion;\r
+ }\r
+\r
+ bool operator<(SamplerYcbcrConversion const & rhs ) const\r
+ {\r
+ return m_samplerYcbcrConversion < rhs.m_samplerYcbcrConversion;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkSamplerYcbcrConversion() const\r
+ {\r
+ return m_samplerYcbcrConversion;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_samplerYcbcrConversion != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_samplerYcbcrConversion == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkSamplerYcbcrConversion m_samplerYcbcrConversion;\r
+ };\r
+\r
+ static_assert( sizeof( SamplerYcbcrConversion ) == sizeof( VkSamplerYcbcrConversion ), "handle and wrapper have different size!" );\r
+\r
+ using SamplerYcbcrConversionKHR = SamplerYcbcrConversion;\r
+\r
+ class ValidationCacheEXT\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR ValidationCacheEXT()\r
+ : m_validationCacheEXT(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR ValidationCacheEXT( std::nullptr_t )\r
+ : m_validationCacheEXT(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT ValidationCacheEXT( VkValidationCacheEXT validationCacheEXT )\r
+ : m_validationCacheEXT( validationCacheEXT )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ ValidationCacheEXT & operator=(VkValidationCacheEXT validationCacheEXT)\r
+ {\r
+ m_validationCacheEXT = validationCacheEXT;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ ValidationCacheEXT & operator=( std::nullptr_t )\r
+ {\r
+ m_validationCacheEXT = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( ValidationCacheEXT const & rhs ) const\r
+ {\r
+ return m_validationCacheEXT == rhs.m_validationCacheEXT;\r
+ }\r
+\r
+ bool operator!=(ValidationCacheEXT const & rhs ) const\r
+ {\r
+ return m_validationCacheEXT != rhs.m_validationCacheEXT;\r
+ }\r
+\r
+ bool operator<(ValidationCacheEXT const & rhs ) const\r
+ {\r
+ return m_validationCacheEXT < rhs.m_validationCacheEXT;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkValidationCacheEXT() const\r
+ {\r
+ return m_validationCacheEXT;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_validationCacheEXT != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_validationCacheEXT == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkValidationCacheEXT m_validationCacheEXT;\r
+ };\r
+\r
+ static_assert( sizeof( ValidationCacheEXT ) == sizeof( VkValidationCacheEXT ), "handle and wrapper have different size!" );\r
+\r
+ class DisplayKHR\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DisplayKHR()\r
+ : m_displayKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DisplayKHR( std::nullptr_t )\r
+ : m_displayKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DisplayKHR( VkDisplayKHR displayKHR )\r
+ : m_displayKHR( displayKHR )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DisplayKHR & operator=(VkDisplayKHR displayKHR)\r
+ {\r
+ m_displayKHR = displayKHR;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DisplayKHR & operator=( std::nullptr_t )\r
+ {\r
+ m_displayKHR = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DisplayKHR const & rhs ) const\r
+ {\r
+ return m_displayKHR == rhs.m_displayKHR;\r
+ }\r
+\r
+ bool operator!=(DisplayKHR const & rhs ) const\r
+ {\r
+ return m_displayKHR != rhs.m_displayKHR;\r
+ }\r
+\r
+ bool operator<(DisplayKHR const & rhs ) const\r
+ {\r
+ return m_displayKHR < rhs.m_displayKHR;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDisplayKHR() const\r
+ {\r
+ return m_displayKHR;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_displayKHR != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_displayKHR == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDisplayKHR m_displayKHR;\r
+ };\r
+\r
+ static_assert( sizeof( DisplayKHR ) == sizeof( VkDisplayKHR ), "handle and wrapper have different size!" );\r
+\r
+ class DisplayModeKHR\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DisplayModeKHR()\r
+ : m_displayModeKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DisplayModeKHR( std::nullptr_t )\r
+ : m_displayModeKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DisplayModeKHR( VkDisplayModeKHR displayModeKHR )\r
+ : m_displayModeKHR( displayModeKHR )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DisplayModeKHR & operator=(VkDisplayModeKHR displayModeKHR)\r
+ {\r
+ m_displayModeKHR = displayModeKHR;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DisplayModeKHR & operator=( std::nullptr_t )\r
+ {\r
+ m_displayModeKHR = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DisplayModeKHR const & rhs ) const\r
+ {\r
+ return m_displayModeKHR == rhs.m_displayModeKHR;\r
+ }\r
+\r
+ bool operator!=(DisplayModeKHR const & rhs ) const\r
+ {\r
+ return m_displayModeKHR != rhs.m_displayModeKHR;\r
+ }\r
+\r
+ bool operator<(DisplayModeKHR const & rhs ) const\r
+ {\r
+ return m_displayModeKHR < rhs.m_displayModeKHR;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDisplayModeKHR() const\r
+ {\r
+ return m_displayModeKHR;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_displayModeKHR != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_displayModeKHR == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDisplayModeKHR m_displayModeKHR;\r
+ };\r
+\r
+ static_assert( sizeof( DisplayModeKHR ) == sizeof( VkDisplayModeKHR ), "handle and wrapper have different size!" );\r
+\r
+ class SurfaceKHR\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR SurfaceKHR()\r
+ : m_surfaceKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR SurfaceKHR( std::nullptr_t )\r
+ : m_surfaceKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT SurfaceKHR( VkSurfaceKHR surfaceKHR )\r
+ : m_surfaceKHR( surfaceKHR )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ SurfaceKHR & operator=(VkSurfaceKHR surfaceKHR)\r
+ {\r
+ m_surfaceKHR = surfaceKHR;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ SurfaceKHR & operator=( std::nullptr_t )\r
+ {\r
+ m_surfaceKHR = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( SurfaceKHR const & rhs ) const\r
+ {\r
+ return m_surfaceKHR == rhs.m_surfaceKHR;\r
+ }\r
+\r
+ bool operator!=(SurfaceKHR const & rhs ) const\r
+ {\r
+ return m_surfaceKHR != rhs.m_surfaceKHR;\r
+ }\r
+\r
+ bool operator<(SurfaceKHR const & rhs ) const\r
+ {\r
+ return m_surfaceKHR < rhs.m_surfaceKHR;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkSurfaceKHR() const\r
+ {\r
+ return m_surfaceKHR;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_surfaceKHR != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_surfaceKHR == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkSurfaceKHR m_surfaceKHR;\r
+ };\r
+\r
+ static_assert( sizeof( SurfaceKHR ) == sizeof( VkSurfaceKHR ), "handle and wrapper have different size!" );\r
+\r
+ class SwapchainKHR\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR SwapchainKHR()\r
+ : m_swapchainKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR SwapchainKHR( std::nullptr_t )\r
+ : m_swapchainKHR(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT SwapchainKHR( VkSwapchainKHR swapchainKHR )\r
+ : m_swapchainKHR( swapchainKHR )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ SwapchainKHR & operator=(VkSwapchainKHR swapchainKHR)\r
+ {\r
+ m_swapchainKHR = swapchainKHR;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ SwapchainKHR & operator=( std::nullptr_t )\r
+ {\r
+ m_swapchainKHR = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( SwapchainKHR const & rhs ) const\r
+ {\r
+ return m_swapchainKHR == rhs.m_swapchainKHR;\r
+ }\r
+\r
+ bool operator!=(SwapchainKHR const & rhs ) const\r
+ {\r
+ return m_swapchainKHR != rhs.m_swapchainKHR;\r
+ }\r
+\r
+ bool operator<(SwapchainKHR const & rhs ) const\r
+ {\r
+ return m_swapchainKHR < rhs.m_swapchainKHR;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkSwapchainKHR() const\r
+ {\r
+ return m_swapchainKHR;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_swapchainKHR != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_swapchainKHR == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkSwapchainKHR m_swapchainKHR;\r
+ };\r
+\r
+ static_assert( sizeof( SwapchainKHR ) == sizeof( VkSwapchainKHR ), "handle and wrapper have different size!" );\r
+\r
+ class DebugReportCallbackEXT\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DebugReportCallbackEXT()\r
+ : m_debugReportCallbackEXT(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DebugReportCallbackEXT( std::nullptr_t )\r
+ : m_debugReportCallbackEXT(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DebugReportCallbackEXT( VkDebugReportCallbackEXT debugReportCallbackEXT )\r
+ : m_debugReportCallbackEXT( debugReportCallbackEXT )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DebugReportCallbackEXT & operator=(VkDebugReportCallbackEXT debugReportCallbackEXT)\r
+ {\r
+ m_debugReportCallbackEXT = debugReportCallbackEXT;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DebugReportCallbackEXT & operator=( std::nullptr_t )\r
+ {\r
+ m_debugReportCallbackEXT = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DebugReportCallbackEXT const & rhs ) const\r
+ {\r
+ return m_debugReportCallbackEXT == rhs.m_debugReportCallbackEXT;\r
+ }\r
+\r
+ bool operator!=(DebugReportCallbackEXT const & rhs ) const\r
+ {\r
+ return m_debugReportCallbackEXT != rhs.m_debugReportCallbackEXT;\r
+ }\r
+\r
+ bool operator<(DebugReportCallbackEXT const & rhs ) const\r
+ {\r
+ return m_debugReportCallbackEXT < rhs.m_debugReportCallbackEXT;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDebugReportCallbackEXT() const\r
+ {\r
+ return m_debugReportCallbackEXT;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_debugReportCallbackEXT != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_debugReportCallbackEXT == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDebugReportCallbackEXT m_debugReportCallbackEXT;\r
+ };\r
+\r
+ static_assert( sizeof( DebugReportCallbackEXT ) == sizeof( VkDebugReportCallbackEXT ), "handle and wrapper have different size!" );\r
+\r
+ class DebugUtilsMessengerEXT\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR DebugUtilsMessengerEXT()\r
+ : m_debugUtilsMessengerEXT(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR DebugUtilsMessengerEXT( std::nullptr_t )\r
+ : m_debugUtilsMessengerEXT(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT DebugUtilsMessengerEXT( VkDebugUtilsMessengerEXT debugUtilsMessengerEXT )\r
+ : m_debugUtilsMessengerEXT( debugUtilsMessengerEXT )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ DebugUtilsMessengerEXT & operator=(VkDebugUtilsMessengerEXT debugUtilsMessengerEXT)\r
+ {\r
+ m_debugUtilsMessengerEXT = debugUtilsMessengerEXT;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ DebugUtilsMessengerEXT & operator=( std::nullptr_t )\r
+ {\r
+ m_debugUtilsMessengerEXT = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( DebugUtilsMessengerEXT const & rhs ) const\r
+ {\r
+ return m_debugUtilsMessengerEXT == rhs.m_debugUtilsMessengerEXT;\r
+ }\r
+\r
+ bool operator!=(DebugUtilsMessengerEXT const & rhs ) const\r
+ {\r
+ return m_debugUtilsMessengerEXT != rhs.m_debugUtilsMessengerEXT;\r
+ }\r
+\r
+ bool operator<(DebugUtilsMessengerEXT const & rhs ) const\r
+ {\r
+ return m_debugUtilsMessengerEXT < rhs.m_debugUtilsMessengerEXT;\r
+ }\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDebugUtilsMessengerEXT() const\r
+ {\r
+ return m_debugUtilsMessengerEXT;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_debugUtilsMessengerEXT != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_debugUtilsMessengerEXT == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDebugUtilsMessengerEXT m_debugUtilsMessengerEXT;\r
+ };\r
+\r
+ static_assert( sizeof( DebugUtilsMessengerEXT ) == sizeof( VkDebugUtilsMessengerEXT ), "handle and wrapper have different size!" );\r
+\r
+ struct Offset2D\r
+ {\r
+ Offset2D( int32_t x_ = 0, int32_t y_ = 0 )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ {\r
+ }\r
+\r
+ Offset2D( VkOffset2D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Offset2D ) );\r
+ }\r
+\r
+ Offset2D& operator=( VkOffset2D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Offset2D ) );\r
+ return *this;\r
+ }\r
+ Offset2D& setX( int32_t x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ Offset2D& setY( int32_t y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkOffset2D&() const\r
+ {\r
+ return *reinterpret_cast<const VkOffset2D*>(this);\r
+ }\r
+\r
+ bool operator==( Offset2D const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y );\r
+ }\r
+\r
+ bool operator!=( Offset2D const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ int32_t x;\r
+ int32_t y;\r
+ };\r
+ static_assert( sizeof( Offset2D ) == sizeof( VkOffset2D ), "struct and wrapper have different size!" );\r
+\r
+ struct Offset3D\r
+ {\r
+ Offset3D( int32_t x_ = 0, int32_t y_ = 0, int32_t z_ = 0 )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ , z( z_ )\r
+ {\r
+ }\r
+\r
+ Offset3D( VkOffset3D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Offset3D ) );\r
+ }\r
+\r
+ Offset3D& operator=( VkOffset3D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Offset3D ) );\r
+ return *this;\r
+ }\r
+ Offset3D& setX( int32_t x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ Offset3D& setY( int32_t y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ Offset3D& setZ( int32_t z_ )\r
+ {\r
+ z = z_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkOffset3D&() const\r
+ {\r
+ return *reinterpret_cast<const VkOffset3D*>(this);\r
+ }\r
+\r
+ bool operator==( Offset3D const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y )\r
+ && ( z == rhs.z );\r
+ }\r
+\r
+ bool operator!=( Offset3D const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ int32_t x;\r
+ int32_t y;\r
+ int32_t z;\r
+ };\r
+ static_assert( sizeof( Offset3D ) == sizeof( VkOffset3D ), "struct and wrapper have different size!" );\r
+\r
+ struct Extent2D\r
+ {\r
+ Extent2D( uint32_t width_ = 0, uint32_t height_ = 0 )\r
+ : width( width_ )\r
+ , height( height_ )\r
+ {\r
+ }\r
+\r
+ Extent2D( VkExtent2D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Extent2D ) );\r
+ }\r
+\r
+ Extent2D& operator=( VkExtent2D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Extent2D ) );\r
+ return *this;\r
+ }\r
+ Extent2D& setWidth( uint32_t width_ )\r
+ {\r
+ width = width_;\r
+ return *this;\r
+ }\r
+\r
+ Extent2D& setHeight( uint32_t height_ )\r
+ {\r
+ height = height_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExtent2D&() const\r
+ {\r
+ return *reinterpret_cast<const VkExtent2D*>(this);\r
+ }\r
+\r
+ bool operator==( Extent2D const& rhs ) const\r
+ {\r
+ return ( width == rhs.width )\r
+ && ( height == rhs.height );\r
+ }\r
+\r
+ bool operator!=( Extent2D const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t width;\r
+ uint32_t height;\r
+ };\r
+ static_assert( sizeof( Extent2D ) == sizeof( VkExtent2D ), "struct and wrapper have different size!" );\r
+\r
+ struct Extent3D\r
+ {\r
+ Extent3D( uint32_t width_ = 0, uint32_t height_ = 0, uint32_t depth_ = 0 )\r
+ : width( width_ )\r
+ , height( height_ )\r
+ , depth( depth_ )\r
+ {\r
+ }\r
+\r
+ Extent3D( VkExtent3D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Extent3D ) );\r
+ }\r
+\r
+ Extent3D& operator=( VkExtent3D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Extent3D ) );\r
+ return *this;\r
+ }\r
+ Extent3D& setWidth( uint32_t width_ )\r
+ {\r
+ width = width_;\r
+ return *this;\r
+ }\r
+\r
+ Extent3D& setHeight( uint32_t height_ )\r
+ {\r
+ height = height_;\r
+ return *this;\r
+ }\r
+\r
+ Extent3D& setDepth( uint32_t depth_ )\r
+ {\r
+ depth = depth_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExtent3D&() const\r
+ {\r
+ return *reinterpret_cast<const VkExtent3D*>(this);\r
+ }\r
+\r
+ bool operator==( Extent3D const& rhs ) const\r
+ {\r
+ return ( width == rhs.width )\r
+ && ( height == rhs.height )\r
+ && ( depth == rhs.depth );\r
+ }\r
+\r
+ bool operator!=( Extent3D const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t width;\r
+ uint32_t height;\r
+ uint32_t depth;\r
+ };\r
+ static_assert( sizeof( Extent3D ) == sizeof( VkExtent3D ), "struct and wrapper have different size!" );\r
+\r
+ struct Viewport\r
+ {\r
+ Viewport( float x_ = 0, float y_ = 0, float width_ = 0, float height_ = 0, float minDepth_ = 0, float maxDepth_ = 0 )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ , width( width_ )\r
+ , height( height_ )\r
+ , minDepth( minDepth_ )\r
+ , maxDepth( maxDepth_ )\r
+ {\r
+ }\r
+\r
+ Viewport( VkViewport const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Viewport ) );\r
+ }\r
+\r
+ Viewport& operator=( VkViewport const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Viewport ) );\r
+ return *this;\r
+ }\r
+ Viewport& setX( float x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ Viewport& setY( float y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ Viewport& setWidth( float width_ )\r
+ {\r
+ width = width_;\r
+ return *this;\r
+ }\r
+\r
+ Viewport& setHeight( float height_ )\r
+ {\r
+ height = height_;\r
+ return *this;\r
+ }\r
+\r
+ Viewport& setMinDepth( float minDepth_ )\r
+ {\r
+ minDepth = minDepth_;\r
+ return *this;\r
+ }\r
+\r
+ Viewport& setMaxDepth( float maxDepth_ )\r
+ {\r
+ maxDepth = maxDepth_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkViewport&() const\r
+ {\r
+ return *reinterpret_cast<const VkViewport*>(this);\r
+ }\r
+\r
+ bool operator==( Viewport const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y )\r
+ && ( width == rhs.width )\r
+ && ( height == rhs.height )\r
+ && ( minDepth == rhs.minDepth )\r
+ && ( maxDepth == rhs.maxDepth );\r
+ }\r
+\r
+ bool operator!=( Viewport const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ float x;\r
+ float y;\r
+ float width;\r
+ float height;\r
+ float minDepth;\r
+ float maxDepth;\r
+ };\r
+ static_assert( sizeof( Viewport ) == sizeof( VkViewport ), "struct and wrapper have different size!" );\r
+\r
+ struct Rect2D\r
+ {\r
+ Rect2D( Offset2D offset_ = Offset2D(), Extent2D extent_ = Extent2D() )\r
+ : offset( offset_ )\r
+ , extent( extent_ )\r
+ {\r
+ }\r
+\r
+ Rect2D( VkRect2D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Rect2D ) );\r
+ }\r
+\r
+ Rect2D& operator=( VkRect2D const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Rect2D ) );\r
+ return *this;\r
+ }\r
+ Rect2D& setOffset( Offset2D offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ Rect2D& setExtent( Extent2D extent_ )\r
+ {\r
+ extent = extent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRect2D&() const\r
+ {\r
+ return *reinterpret_cast<const VkRect2D*>(this);\r
+ }\r
+\r
+ bool operator==( Rect2D const& rhs ) const\r
+ {\r
+ return ( offset == rhs.offset )\r
+ && ( extent == rhs.extent );\r
+ }\r
+\r
+ bool operator!=( Rect2D const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Offset2D offset;\r
+ Extent2D extent;\r
+ };\r
+ static_assert( sizeof( Rect2D ) == sizeof( VkRect2D ), "struct and wrapper have different size!" );\r
+\r
+ struct ClearRect\r
+ {\r
+ ClearRect( Rect2D rect_ = Rect2D(), uint32_t baseArrayLayer_ = 0, uint32_t layerCount_ = 0 )\r
+ : rect( rect_ )\r
+ , baseArrayLayer( baseArrayLayer_ )\r
+ , layerCount( layerCount_ )\r
+ {\r
+ }\r
+\r
+ ClearRect( VkClearRect const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ClearRect ) );\r
+ }\r
+\r
+ ClearRect& operator=( VkClearRect const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ClearRect ) );\r
+ return *this;\r
+ }\r
+ ClearRect& setRect( Rect2D rect_ )\r
+ {\r
+ rect = rect_;\r
+ return *this;\r
+ }\r
+\r
+ ClearRect& setBaseArrayLayer( uint32_t baseArrayLayer_ )\r
+ {\r
+ baseArrayLayer = baseArrayLayer_;\r
+ return *this;\r
+ }\r
+\r
+ ClearRect& setLayerCount( uint32_t layerCount_ )\r
+ {\r
+ layerCount = layerCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkClearRect&() const\r
+ {\r
+ return *reinterpret_cast<const VkClearRect*>(this);\r
+ }\r
+\r
+ bool operator==( ClearRect const& rhs ) const\r
+ {\r
+ return ( rect == rhs.rect )\r
+ && ( baseArrayLayer == rhs.baseArrayLayer )\r
+ && ( layerCount == rhs.layerCount );\r
+ }\r
+\r
+ bool operator!=( ClearRect const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Rect2D rect;\r
+ uint32_t baseArrayLayer;\r
+ uint32_t layerCount;\r
+ };\r
+ static_assert( sizeof( ClearRect ) == sizeof( VkClearRect ), "struct and wrapper have different size!" );\r
+\r
+ struct ExtensionProperties\r
+ {\r
+ operator const VkExtensionProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkExtensionProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ExtensionProperties const& rhs ) const\r
+ {\r
+ return ( memcmp( extensionName, rhs.extensionName, VK_MAX_EXTENSION_NAME_SIZE * sizeof( char ) ) == 0 )\r
+ && ( specVersion == rhs.specVersion );\r
+ }\r
+\r
+ bool operator!=( ExtensionProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ char extensionName[VK_MAX_EXTENSION_NAME_SIZE];\r
+ uint32_t specVersion;\r
+ };\r
+ static_assert( sizeof( ExtensionProperties ) == sizeof( VkExtensionProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct LayerProperties\r
+ {\r
+ operator const VkLayerProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkLayerProperties*>(this);\r
+ }\r
+\r
+ bool operator==( LayerProperties const& rhs ) const\r
+ {\r
+ return ( memcmp( layerName, rhs.layerName, VK_MAX_EXTENSION_NAME_SIZE * sizeof( char ) ) == 0 )\r
+ && ( specVersion == rhs.specVersion )\r
+ && ( implementationVersion == rhs.implementationVersion )\r
+ && ( memcmp( description, rhs.description, VK_MAX_DESCRIPTION_SIZE * sizeof( char ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( LayerProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ char layerName[VK_MAX_EXTENSION_NAME_SIZE];\r
+ uint32_t specVersion;\r
+ uint32_t implementationVersion;\r
+ char description[VK_MAX_DESCRIPTION_SIZE];\r
+ };\r
+ static_assert( sizeof( LayerProperties ) == sizeof( VkLayerProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct AllocationCallbacks\r
+ {\r
+ AllocationCallbacks( void* pUserData_ = nullptr, PFN_vkAllocationFunction pfnAllocation_ = nullptr, PFN_vkReallocationFunction pfnReallocation_ = nullptr, PFN_vkFreeFunction pfnFree_ = nullptr, PFN_vkInternalAllocationNotification pfnInternalAllocation_ = nullptr, PFN_vkInternalFreeNotification pfnInternalFree_ = nullptr )\r
+ : pUserData( pUserData_ )\r
+ , pfnAllocation( pfnAllocation_ )\r
+ , pfnReallocation( pfnReallocation_ )\r
+ , pfnFree( pfnFree_ )\r
+ , pfnInternalAllocation( pfnInternalAllocation_ )\r
+ , pfnInternalFree( pfnInternalFree_ )\r
+ {\r
+ }\r
+\r
+ AllocationCallbacks( VkAllocationCallbacks const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AllocationCallbacks ) );\r
+ }\r
+\r
+ AllocationCallbacks& operator=( VkAllocationCallbacks const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AllocationCallbacks ) );\r
+ return *this;\r
+ }\r
+ AllocationCallbacks& setPUserData( void* pUserData_ )\r
+ {\r
+ pUserData = pUserData_;\r
+ return *this;\r
+ }\r
+\r
+ AllocationCallbacks& setPfnAllocation( PFN_vkAllocationFunction pfnAllocation_ )\r
+ {\r
+ pfnAllocation = pfnAllocation_;\r
+ return *this;\r
+ }\r
+\r
+ AllocationCallbacks& setPfnReallocation( PFN_vkReallocationFunction pfnReallocation_ )\r
+ {\r
+ pfnReallocation = pfnReallocation_;\r
+ return *this;\r
+ }\r
+\r
+ AllocationCallbacks& setPfnFree( PFN_vkFreeFunction pfnFree_ )\r
+ {\r
+ pfnFree = pfnFree_;\r
+ return *this;\r
+ }\r
+\r
+ AllocationCallbacks& setPfnInternalAllocation( PFN_vkInternalAllocationNotification pfnInternalAllocation_ )\r
+ {\r
+ pfnInternalAllocation = pfnInternalAllocation_;\r
+ return *this;\r
+ }\r
+\r
+ AllocationCallbacks& setPfnInternalFree( PFN_vkInternalFreeNotification pfnInternalFree_ )\r
+ {\r
+ pfnInternalFree = pfnInternalFree_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkAllocationCallbacks&() const\r
+ {\r
+ return *reinterpret_cast<const VkAllocationCallbacks*>(this);\r
+ }\r
+\r
+ bool operator==( AllocationCallbacks const& rhs ) const\r
+ {\r
+ return ( pUserData == rhs.pUserData )\r
+ && ( pfnAllocation == rhs.pfnAllocation )\r
+ && ( pfnReallocation == rhs.pfnReallocation )\r
+ && ( pfnFree == rhs.pfnFree )\r
+ && ( pfnInternalAllocation == rhs.pfnInternalAllocation )\r
+ && ( pfnInternalFree == rhs.pfnInternalFree );\r
+ }\r
+\r
+ bool operator!=( AllocationCallbacks const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ void* pUserData;\r
+ PFN_vkAllocationFunction pfnAllocation;\r
+ PFN_vkReallocationFunction pfnReallocation;\r
+ PFN_vkFreeFunction pfnFree;\r
+ PFN_vkInternalAllocationNotification pfnInternalAllocation;\r
+ PFN_vkInternalFreeNotification pfnInternalFree;\r
+ };\r
+ static_assert( sizeof( AllocationCallbacks ) == sizeof( VkAllocationCallbacks ), "struct and wrapper have different size!" );\r
+\r
+ struct MemoryRequirements\r
+ {\r
+ operator const VkMemoryRequirements&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryRequirements*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryRequirements const& rhs ) const\r
+ {\r
+ return ( size == rhs.size )\r
+ && ( alignment == rhs.alignment )\r
+ && ( memoryTypeBits == rhs.memoryTypeBits );\r
+ }\r
+\r
+ bool operator!=( MemoryRequirements const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DeviceSize size;\r
+ DeviceSize alignment;\r
+ uint32_t memoryTypeBits;\r
+ };\r
+ static_assert( sizeof( MemoryRequirements ) == sizeof( VkMemoryRequirements ), "struct and wrapper have different size!" );\r
+\r
+ struct DescriptorBufferInfo\r
+ {\r
+ DescriptorBufferInfo( Buffer buffer_ = Buffer(), DeviceSize offset_ = 0, DeviceSize range_ = 0 )\r
+ : buffer( buffer_ )\r
+ , offset( offset_ )\r
+ , range( range_ )\r
+ {\r
+ }\r
+\r
+ DescriptorBufferInfo( VkDescriptorBufferInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorBufferInfo ) );\r
+ }\r
+\r
+ DescriptorBufferInfo& operator=( VkDescriptorBufferInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorBufferInfo ) );\r
+ return *this;\r
+ }\r
+ DescriptorBufferInfo& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorBufferInfo& setOffset( DeviceSize offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorBufferInfo& setRange( DeviceSize range_ )\r
+ {\r
+ range = range_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorBufferInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorBufferInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorBufferInfo const& rhs ) const\r
+ {\r
+ return ( buffer == rhs.buffer )\r
+ && ( offset == rhs.offset )\r
+ && ( range == rhs.range );\r
+ }\r
+\r
+ bool operator!=( DescriptorBufferInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Buffer buffer;\r
+ DeviceSize offset;\r
+ DeviceSize range;\r
+ };\r
+ static_assert( sizeof( DescriptorBufferInfo ) == sizeof( VkDescriptorBufferInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct SubresourceLayout\r
+ {\r
+ operator const VkSubresourceLayout&() const\r
+ {\r
+ return *reinterpret_cast<const VkSubresourceLayout*>(this);\r
+ }\r
+\r
+ bool operator==( SubresourceLayout const& rhs ) const\r
+ {\r
+ return ( offset == rhs.offset )\r
+ && ( size == rhs.size )\r
+ && ( rowPitch == rhs.rowPitch )\r
+ && ( arrayPitch == rhs.arrayPitch )\r
+ && ( depthPitch == rhs.depthPitch );\r
+ }\r
+\r
+ bool operator!=( SubresourceLayout const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DeviceSize offset;\r
+ DeviceSize size;\r
+ DeviceSize rowPitch;\r
+ DeviceSize arrayPitch;\r
+ DeviceSize depthPitch;\r
+ };\r
+ static_assert( sizeof( SubresourceLayout ) == sizeof( VkSubresourceLayout ), "struct and wrapper have different size!" );\r
+\r
+ struct BufferCopy\r
+ {\r
+ BufferCopy( DeviceSize srcOffset_ = 0, DeviceSize dstOffset_ = 0, DeviceSize size_ = 0 )\r
+ : srcOffset( srcOffset_ )\r
+ , dstOffset( dstOffset_ )\r
+ , size( size_ )\r
+ {\r
+ }\r
+\r
+ BufferCopy( VkBufferCopy const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferCopy ) );\r
+ }\r
+\r
+ BufferCopy& operator=( VkBufferCopy const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferCopy ) );\r
+ return *this;\r
+ }\r
+ BufferCopy& setSrcOffset( DeviceSize srcOffset_ )\r
+ {\r
+ srcOffset = srcOffset_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCopy& setDstOffset( DeviceSize dstOffset_ )\r
+ {\r
+ dstOffset = dstOffset_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCopy& setSize( DeviceSize size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBufferCopy&() const\r
+ {\r
+ return *reinterpret_cast<const VkBufferCopy*>(this);\r
+ }\r
+\r
+ bool operator==( BufferCopy const& rhs ) const\r
+ {\r
+ return ( srcOffset == rhs.srcOffset )\r
+ && ( dstOffset == rhs.dstOffset )\r
+ && ( size == rhs.size );\r
+ }\r
+\r
+ bool operator!=( BufferCopy const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DeviceSize srcOffset;\r
+ DeviceSize dstOffset;\r
+ DeviceSize size;\r
+ };\r
+ static_assert( sizeof( BufferCopy ) == sizeof( VkBufferCopy ), "struct and wrapper have different size!" );\r
+\r
+ struct SpecializationMapEntry\r
+ {\r
+ SpecializationMapEntry( uint32_t constantID_ = 0, uint32_t offset_ = 0, size_t size_ = 0 )\r
+ : constantID( constantID_ )\r
+ , offset( offset_ )\r
+ , size( size_ )\r
+ {\r
+ }\r
+\r
+ SpecializationMapEntry( VkSpecializationMapEntry const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SpecializationMapEntry ) );\r
+ }\r
+\r
+ SpecializationMapEntry& operator=( VkSpecializationMapEntry const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SpecializationMapEntry ) );\r
+ return *this;\r
+ }\r
+ SpecializationMapEntry& setConstantID( uint32_t constantID_ )\r
+ {\r
+ constantID = constantID_;\r
+ return *this;\r
+ }\r
+\r
+ SpecializationMapEntry& setOffset( uint32_t offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ SpecializationMapEntry& setSize( size_t size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSpecializationMapEntry&() const\r
+ {\r
+ return *reinterpret_cast<const VkSpecializationMapEntry*>(this);\r
+ }\r
+\r
+ bool operator==( SpecializationMapEntry const& rhs ) const\r
+ {\r
+ return ( constantID == rhs.constantID )\r
+ && ( offset == rhs.offset )\r
+ && ( size == rhs.size );\r
+ }\r
+\r
+ bool operator!=( SpecializationMapEntry const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t constantID;\r
+ uint32_t offset;\r
+ size_t size;\r
+ };\r
+ static_assert( sizeof( SpecializationMapEntry ) == sizeof( VkSpecializationMapEntry ), "struct and wrapper have different size!" );\r
+\r
+ struct SpecializationInfo\r
+ {\r
+ SpecializationInfo( uint32_t mapEntryCount_ = 0, const SpecializationMapEntry* pMapEntries_ = nullptr, size_t dataSize_ = 0, const void* pData_ = nullptr )\r
+ : mapEntryCount( mapEntryCount_ )\r
+ , pMapEntries( pMapEntries_ )\r
+ , dataSize( dataSize_ )\r
+ , pData( pData_ )\r
+ {\r
+ }\r
+\r
+ SpecializationInfo( VkSpecializationInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SpecializationInfo ) );\r
+ }\r
+\r
+ SpecializationInfo& operator=( VkSpecializationInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SpecializationInfo ) );\r
+ return *this;\r
+ }\r
+ SpecializationInfo& setMapEntryCount( uint32_t mapEntryCount_ )\r
+ {\r
+ mapEntryCount = mapEntryCount_;\r
+ return *this;\r
+ }\r
+\r
+ SpecializationInfo& setPMapEntries( const SpecializationMapEntry* pMapEntries_ )\r
+ {\r
+ pMapEntries = pMapEntries_;\r
+ return *this;\r
+ }\r
+\r
+ SpecializationInfo& setDataSize( size_t dataSize_ )\r
+ {\r
+ dataSize = dataSize_;\r
+ return *this;\r
+ }\r
+\r
+ SpecializationInfo& setPData( const void* pData_ )\r
+ {\r
+ pData = pData_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSpecializationInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSpecializationInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SpecializationInfo const& rhs ) const\r
+ {\r
+ return ( mapEntryCount == rhs.mapEntryCount )\r
+ && ( pMapEntries == rhs.pMapEntries )\r
+ && ( dataSize == rhs.dataSize )\r
+ && ( pData == rhs.pData );\r
+ }\r
+\r
+ bool operator!=( SpecializationInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t mapEntryCount;\r
+ const SpecializationMapEntry* pMapEntries;\r
+ size_t dataSize;\r
+ const void* pData;\r
+ };\r
+ static_assert( sizeof( SpecializationInfo ) == sizeof( VkSpecializationInfo ), "struct and wrapper have different size!" );\r
+\r
+ union ClearColorValue\r
+ {\r
+ ClearColorValue( const std::array<float,4>& float32_ = { {0} } )\r
+ {\r
+ memcpy( &float32, float32_.data(), 4 * sizeof( float ) );\r
+ }\r
+\r
+ ClearColorValue( const std::array<int32_t,4>& int32_ )\r
+ {\r
+ memcpy( &int32, int32_.data(), 4 * sizeof( int32_t ) );\r
+ }\r
+\r
+ ClearColorValue( const std::array<uint32_t,4>& uint32_ )\r
+ {\r
+ memcpy( &uint32, uint32_.data(), 4 * sizeof( uint32_t ) );\r
+ }\r
+\r
+ ClearColorValue& setFloat32( std::array<float,4> float32_ )\r
+ {\r
+ memcpy( &float32, float32_.data(), 4 * sizeof( float ) );\r
+ return *this;\r
+ }\r
+\r
+ ClearColorValue& setInt32( std::array<int32_t,4> int32_ )\r
+ {\r
+ memcpy( &int32, int32_.data(), 4 * sizeof( int32_t ) );\r
+ return *this;\r
+ }\r
+\r
+ ClearColorValue& setUint32( std::array<uint32_t,4> uint32_ )\r
+ {\r
+ memcpy( &uint32, uint32_.data(), 4 * sizeof( uint32_t ) );\r
+ return *this;\r
+ }\r
+\r
+ operator VkClearColorValue const& () const\r
+ {\r
+ return *reinterpret_cast<const VkClearColorValue*>(this);\r
+ }\r
+\r
+ float float32[4];\r
+ int32_t int32[4];\r
+ uint32_t uint32[4];\r
+ };\r
+\r
+ struct ClearDepthStencilValue\r
+ {\r
+ ClearDepthStencilValue( float depth_ = 0, uint32_t stencil_ = 0 )\r
+ : depth( depth_ )\r
+ , stencil( stencil_ )\r
+ {\r
+ }\r
+\r
+ ClearDepthStencilValue( VkClearDepthStencilValue const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ClearDepthStencilValue ) );\r
+ }\r
+\r
+ ClearDepthStencilValue& operator=( VkClearDepthStencilValue const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ClearDepthStencilValue ) );\r
+ return *this;\r
+ }\r
+ ClearDepthStencilValue& setDepth( float depth_ )\r
+ {\r
+ depth = depth_;\r
+ return *this;\r
+ }\r
+\r
+ ClearDepthStencilValue& setStencil( uint32_t stencil_ )\r
+ {\r
+ stencil = stencil_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkClearDepthStencilValue&() const\r
+ {\r
+ return *reinterpret_cast<const VkClearDepthStencilValue*>(this);\r
+ }\r
+\r
+ bool operator==( ClearDepthStencilValue const& rhs ) const\r
+ {\r
+ return ( depth == rhs.depth )\r
+ && ( stencil == rhs.stencil );\r
+ }\r
+\r
+ bool operator!=( ClearDepthStencilValue const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ float depth;\r
+ uint32_t stencil;\r
+ };\r
+ static_assert( sizeof( ClearDepthStencilValue ) == sizeof( VkClearDepthStencilValue ), "struct and wrapper have different size!" );\r
+\r
+ union ClearValue\r
+ {\r
+ ClearValue( ClearColorValue color_ = ClearColorValue() )\r
+ {\r
+ color = color_;\r
+ }\r
+\r
+ ClearValue( ClearDepthStencilValue depthStencil_ )\r
+ {\r
+ depthStencil = depthStencil_;\r
+ }\r
+\r
+ ClearValue& setColor( ClearColorValue color_ )\r
+ {\r
+ color = color_;\r
+ return *this;\r
+ }\r
+\r
+ ClearValue& setDepthStencil( ClearDepthStencilValue depthStencil_ )\r
+ {\r
+ depthStencil = depthStencil_;\r
+ return *this;\r
+ }\r
+\r
+ operator VkClearValue const& () const\r
+ {\r
+ return *reinterpret_cast<const VkClearValue*>(this);\r
+ }\r
+\r
+#ifdef VULKAN_HPP_HAS_UNRESTRICTED_UNIONS\r
+ ClearColorValue color;\r
+ ClearDepthStencilValue depthStencil;\r
+#else\r
+ VkClearColorValue color;\r
+ VkClearDepthStencilValue depthStencil;\r
+#endif // VULKAN_HPP_HAS_UNRESTRICTED_UNIONS\r
+ };\r
+\r
+ struct PhysicalDeviceFeatures\r
+ {\r
+ PhysicalDeviceFeatures( Bool32 robustBufferAccess_ = 0, Bool32 fullDrawIndexUint32_ = 0, Bool32 imageCubeArray_ = 0, Bool32 independentBlend_ = 0, Bool32 geometryShader_ = 0, Bool32 tessellationShader_ = 0, Bool32 sampleRateShading_ = 0, Bool32 dualSrcBlend_ = 0, Bool32 logicOp_ = 0, Bool32 multiDrawIndirect_ = 0, Bool32 drawIndirectFirstInstance_ = 0, Bool32 depthClamp_ = 0, Bool32 depthBiasClamp_ = 0, Bool32 fillModeNonSolid_ = 0, Bool32 depthBounds_ = 0, Bool32 wideLines_ = 0, Bool32 largePoints_ = 0, Bool32 alphaToOne_ = 0, Bool32 multiViewport_ = 0, Bool32 samplerAnisotropy_ = 0, Bool32 textureCompressionETC2_ = 0, Bool32 textureCompressionASTC_LDR_ = 0, Bool32 textureCompressionBC_ = 0, Bool32 occlusionQueryPrecise_ = 0, Bool32 pipelineStatisticsQuery_ = 0, Bool32 vertexPipelineStoresAndAtomics_ = 0, Bool32 fragmentStoresAndAtomics_ = 0, Bool32 shaderTessellationAndGeometryPointSize_ = 0, Bool32 shaderImageGatherExtended_ = 0, Bool32 shaderStorageImageExtendedFormats_ = 0, Bool32 shaderStorageImageMultisample_ = 0, Bool32 shaderStorageImageReadWithoutFormat_ = 0, Bool32 shaderStorageImageWriteWithoutFormat_ = 0, Bool32 shaderUniformBufferArrayDynamicIndexing_ = 0, Bool32 shaderSampledImageArrayDynamicIndexing_ = 0, Bool32 shaderStorageBufferArrayDynamicIndexing_ = 0, Bool32 shaderStorageImageArrayDynamicIndexing_ = 0, Bool32 shaderClipDistance_ = 0, Bool32 shaderCullDistance_ = 0, Bool32 shaderFloat64_ = 0, Bool32 shaderInt64_ = 0, Bool32 shaderInt16_ = 0, Bool32 shaderResourceResidency_ = 0, Bool32 shaderResourceMinLod_ = 0, Bool32 sparseBinding_ = 0, Bool32 sparseResidencyBuffer_ = 0, Bool32 sparseResidencyImage2D_ = 0, Bool32 sparseResidencyImage3D_ = 0, Bool32 sparseResidency2Samples_ = 0, Bool32 sparseResidency4Samples_ = 0, Bool32 sparseResidency8Samples_ = 0, Bool32 sparseResidency16Samples_ = 0, Bool32 sparseResidencyAliased_ = 0, Bool32 variableMultisampleRate_ = 0, Bool32 inheritedQueries_ = 0 )\r
+ : robustBufferAccess( robustBufferAccess_ )\r
+ , fullDrawIndexUint32( fullDrawIndexUint32_ )\r
+ , imageCubeArray( imageCubeArray_ )\r
+ , independentBlend( independentBlend_ )\r
+ , geometryShader( geometryShader_ )\r
+ , tessellationShader( tessellationShader_ )\r
+ , sampleRateShading( sampleRateShading_ )\r
+ , dualSrcBlend( dualSrcBlend_ )\r
+ , logicOp( logicOp_ )\r
+ , multiDrawIndirect( multiDrawIndirect_ )\r
+ , drawIndirectFirstInstance( drawIndirectFirstInstance_ )\r
+ , depthClamp( depthClamp_ )\r
+ , depthBiasClamp( depthBiasClamp_ )\r
+ , fillModeNonSolid( fillModeNonSolid_ )\r
+ , depthBounds( depthBounds_ )\r
+ , wideLines( wideLines_ )\r
+ , largePoints( largePoints_ )\r
+ , alphaToOne( alphaToOne_ )\r
+ , multiViewport( multiViewport_ )\r
+ , samplerAnisotropy( samplerAnisotropy_ )\r
+ , textureCompressionETC2( textureCompressionETC2_ )\r
+ , textureCompressionASTC_LDR( textureCompressionASTC_LDR_ )\r
+ , textureCompressionBC( textureCompressionBC_ )\r
+ , occlusionQueryPrecise( occlusionQueryPrecise_ )\r
+ , pipelineStatisticsQuery( pipelineStatisticsQuery_ )\r
+ , vertexPipelineStoresAndAtomics( vertexPipelineStoresAndAtomics_ )\r
+ , fragmentStoresAndAtomics( fragmentStoresAndAtomics_ )\r
+ , shaderTessellationAndGeometryPointSize( shaderTessellationAndGeometryPointSize_ )\r
+ , shaderImageGatherExtended( shaderImageGatherExtended_ )\r
+ , shaderStorageImageExtendedFormats( shaderStorageImageExtendedFormats_ )\r
+ , shaderStorageImageMultisample( shaderStorageImageMultisample_ )\r
+ , shaderStorageImageReadWithoutFormat( shaderStorageImageReadWithoutFormat_ )\r
+ , shaderStorageImageWriteWithoutFormat( shaderStorageImageWriteWithoutFormat_ )\r
+ , shaderUniformBufferArrayDynamicIndexing( shaderUniformBufferArrayDynamicIndexing_ )\r
+ , shaderSampledImageArrayDynamicIndexing( shaderSampledImageArrayDynamicIndexing_ )\r
+ , shaderStorageBufferArrayDynamicIndexing( shaderStorageBufferArrayDynamicIndexing_ )\r
+ , shaderStorageImageArrayDynamicIndexing( shaderStorageImageArrayDynamicIndexing_ )\r
+ , shaderClipDistance( shaderClipDistance_ )\r
+ , shaderCullDistance( shaderCullDistance_ )\r
+ , shaderFloat64( shaderFloat64_ )\r
+ , shaderInt64( shaderInt64_ )\r
+ , shaderInt16( shaderInt16_ )\r
+ , shaderResourceResidency( shaderResourceResidency_ )\r
+ , shaderResourceMinLod( shaderResourceMinLod_ )\r
+ , sparseBinding( sparseBinding_ )\r
+ , sparseResidencyBuffer( sparseResidencyBuffer_ )\r
+ , sparseResidencyImage2D( sparseResidencyImage2D_ )\r
+ , sparseResidencyImage3D( sparseResidencyImage3D_ )\r
+ , sparseResidency2Samples( sparseResidency2Samples_ )\r
+ , sparseResidency4Samples( sparseResidency4Samples_ )\r
+ , sparseResidency8Samples( sparseResidency8Samples_ )\r
+ , sparseResidency16Samples( sparseResidency16Samples_ )\r
+ , sparseResidencyAliased( sparseResidencyAliased_ )\r
+ , variableMultisampleRate( variableMultisampleRate_ )\r
+ , inheritedQueries( inheritedQueries_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceFeatures( VkPhysicalDeviceFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceFeatures ) );\r
+ }\r
+\r
+ PhysicalDeviceFeatures& operator=( VkPhysicalDeviceFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceFeatures& setRobustBufferAccess( Bool32 robustBufferAccess_ )\r
+ {\r
+ robustBufferAccess = robustBufferAccess_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setFullDrawIndexUint32( Bool32 fullDrawIndexUint32_ )\r
+ {\r
+ fullDrawIndexUint32 = fullDrawIndexUint32_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setImageCubeArray( Bool32 imageCubeArray_ )\r
+ {\r
+ imageCubeArray = imageCubeArray_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setIndependentBlend( Bool32 independentBlend_ )\r
+ {\r
+ independentBlend = independentBlend_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setGeometryShader( Bool32 geometryShader_ )\r
+ {\r
+ geometryShader = geometryShader_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setTessellationShader( Bool32 tessellationShader_ )\r
+ {\r
+ tessellationShader = tessellationShader_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSampleRateShading( Bool32 sampleRateShading_ )\r
+ {\r
+ sampleRateShading = sampleRateShading_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setDualSrcBlend( Bool32 dualSrcBlend_ )\r
+ {\r
+ dualSrcBlend = dualSrcBlend_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setLogicOp( Bool32 logicOp_ )\r
+ {\r
+ logicOp = logicOp_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setMultiDrawIndirect( Bool32 multiDrawIndirect_ )\r
+ {\r
+ multiDrawIndirect = multiDrawIndirect_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setDrawIndirectFirstInstance( Bool32 drawIndirectFirstInstance_ )\r
+ {\r
+ drawIndirectFirstInstance = drawIndirectFirstInstance_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setDepthClamp( Bool32 depthClamp_ )\r
+ {\r
+ depthClamp = depthClamp_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setDepthBiasClamp( Bool32 depthBiasClamp_ )\r
+ {\r
+ depthBiasClamp = depthBiasClamp_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setFillModeNonSolid( Bool32 fillModeNonSolid_ )\r
+ {\r
+ fillModeNonSolid = fillModeNonSolid_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setDepthBounds( Bool32 depthBounds_ )\r
+ {\r
+ depthBounds = depthBounds_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setWideLines( Bool32 wideLines_ )\r
+ {\r
+ wideLines = wideLines_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setLargePoints( Bool32 largePoints_ )\r
+ {\r
+ largePoints = largePoints_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setAlphaToOne( Bool32 alphaToOne_ )\r
+ {\r
+ alphaToOne = alphaToOne_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setMultiViewport( Bool32 multiViewport_ )\r
+ {\r
+ multiViewport = multiViewport_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSamplerAnisotropy( Bool32 samplerAnisotropy_ )\r
+ {\r
+ samplerAnisotropy = samplerAnisotropy_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setTextureCompressionETC2( Bool32 textureCompressionETC2_ )\r
+ {\r
+ textureCompressionETC2 = textureCompressionETC2_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setTextureCompressionASTC_LDR( Bool32 textureCompressionASTC_LDR_ )\r
+ {\r
+ textureCompressionASTC_LDR = textureCompressionASTC_LDR_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setTextureCompressionBC( Bool32 textureCompressionBC_ )\r
+ {\r
+ textureCompressionBC = textureCompressionBC_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setOcclusionQueryPrecise( Bool32 occlusionQueryPrecise_ )\r
+ {\r
+ occlusionQueryPrecise = occlusionQueryPrecise_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setPipelineStatisticsQuery( Bool32 pipelineStatisticsQuery_ )\r
+ {\r
+ pipelineStatisticsQuery = pipelineStatisticsQuery_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setVertexPipelineStoresAndAtomics( Bool32 vertexPipelineStoresAndAtomics_ )\r
+ {\r
+ vertexPipelineStoresAndAtomics = vertexPipelineStoresAndAtomics_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setFragmentStoresAndAtomics( Bool32 fragmentStoresAndAtomics_ )\r
+ {\r
+ fragmentStoresAndAtomics = fragmentStoresAndAtomics_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderTessellationAndGeometryPointSize( Bool32 shaderTessellationAndGeometryPointSize_ )\r
+ {\r
+ shaderTessellationAndGeometryPointSize = shaderTessellationAndGeometryPointSize_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderImageGatherExtended( Bool32 shaderImageGatherExtended_ )\r
+ {\r
+ shaderImageGatherExtended = shaderImageGatherExtended_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderStorageImageExtendedFormats( Bool32 shaderStorageImageExtendedFormats_ )\r
+ {\r
+ shaderStorageImageExtendedFormats = shaderStorageImageExtendedFormats_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderStorageImageMultisample( Bool32 shaderStorageImageMultisample_ )\r
+ {\r
+ shaderStorageImageMultisample = shaderStorageImageMultisample_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderStorageImageReadWithoutFormat( Bool32 shaderStorageImageReadWithoutFormat_ )\r
+ {\r
+ shaderStorageImageReadWithoutFormat = shaderStorageImageReadWithoutFormat_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderStorageImageWriteWithoutFormat( Bool32 shaderStorageImageWriteWithoutFormat_ )\r
+ {\r
+ shaderStorageImageWriteWithoutFormat = shaderStorageImageWriteWithoutFormat_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderUniformBufferArrayDynamicIndexing( Bool32 shaderUniformBufferArrayDynamicIndexing_ )\r
+ {\r
+ shaderUniformBufferArrayDynamicIndexing = shaderUniformBufferArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderSampledImageArrayDynamicIndexing( Bool32 shaderSampledImageArrayDynamicIndexing_ )\r
+ {\r
+ shaderSampledImageArrayDynamicIndexing = shaderSampledImageArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderStorageBufferArrayDynamicIndexing( Bool32 shaderStorageBufferArrayDynamicIndexing_ )\r
+ {\r
+ shaderStorageBufferArrayDynamicIndexing = shaderStorageBufferArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderStorageImageArrayDynamicIndexing( Bool32 shaderStorageImageArrayDynamicIndexing_ )\r
+ {\r
+ shaderStorageImageArrayDynamicIndexing = shaderStorageImageArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderClipDistance( Bool32 shaderClipDistance_ )\r
+ {\r
+ shaderClipDistance = shaderClipDistance_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderCullDistance( Bool32 shaderCullDistance_ )\r
+ {\r
+ shaderCullDistance = shaderCullDistance_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderFloat64( Bool32 shaderFloat64_ )\r
+ {\r
+ shaderFloat64 = shaderFloat64_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderInt64( Bool32 shaderInt64_ )\r
+ {\r
+ shaderInt64 = shaderInt64_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderInt16( Bool32 shaderInt16_ )\r
+ {\r
+ shaderInt16 = shaderInt16_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderResourceResidency( Bool32 shaderResourceResidency_ )\r
+ {\r
+ shaderResourceResidency = shaderResourceResidency_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setShaderResourceMinLod( Bool32 shaderResourceMinLod_ )\r
+ {\r
+ shaderResourceMinLod = shaderResourceMinLod_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseBinding( Bool32 sparseBinding_ )\r
+ {\r
+ sparseBinding = sparseBinding_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidencyBuffer( Bool32 sparseResidencyBuffer_ )\r
+ {\r
+ sparseResidencyBuffer = sparseResidencyBuffer_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidencyImage2D( Bool32 sparseResidencyImage2D_ )\r
+ {\r
+ sparseResidencyImage2D = sparseResidencyImage2D_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidencyImage3D( Bool32 sparseResidencyImage3D_ )\r
+ {\r
+ sparseResidencyImage3D = sparseResidencyImage3D_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidency2Samples( Bool32 sparseResidency2Samples_ )\r
+ {\r
+ sparseResidency2Samples = sparseResidency2Samples_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidency4Samples( Bool32 sparseResidency4Samples_ )\r
+ {\r
+ sparseResidency4Samples = sparseResidency4Samples_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidency8Samples( Bool32 sparseResidency8Samples_ )\r
+ {\r
+ sparseResidency8Samples = sparseResidency8Samples_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidency16Samples( Bool32 sparseResidency16Samples_ )\r
+ {\r
+ sparseResidency16Samples = sparseResidency16Samples_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setSparseResidencyAliased( Bool32 sparseResidencyAliased_ )\r
+ {\r
+ sparseResidencyAliased = sparseResidencyAliased_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setVariableMultisampleRate( Bool32 variableMultisampleRate_ )\r
+ {\r
+ variableMultisampleRate = variableMultisampleRate_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures& setInheritedQueries( Bool32 inheritedQueries_ )\r
+ {\r
+ inheritedQueries = inheritedQueries_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceFeatures const& rhs ) const\r
+ {\r
+ return ( robustBufferAccess == rhs.robustBufferAccess )\r
+ && ( fullDrawIndexUint32 == rhs.fullDrawIndexUint32 )\r
+ && ( imageCubeArray == rhs.imageCubeArray )\r
+ && ( independentBlend == rhs.independentBlend )\r
+ && ( geometryShader == rhs.geometryShader )\r
+ && ( tessellationShader == rhs.tessellationShader )\r
+ && ( sampleRateShading == rhs.sampleRateShading )\r
+ && ( dualSrcBlend == rhs.dualSrcBlend )\r
+ && ( logicOp == rhs.logicOp )\r
+ && ( multiDrawIndirect == rhs.multiDrawIndirect )\r
+ && ( drawIndirectFirstInstance == rhs.drawIndirectFirstInstance )\r
+ && ( depthClamp == rhs.depthClamp )\r
+ && ( depthBiasClamp == rhs.depthBiasClamp )\r
+ && ( fillModeNonSolid == rhs.fillModeNonSolid )\r
+ && ( depthBounds == rhs.depthBounds )\r
+ && ( wideLines == rhs.wideLines )\r
+ && ( largePoints == rhs.largePoints )\r
+ && ( alphaToOne == rhs.alphaToOne )\r
+ && ( multiViewport == rhs.multiViewport )\r
+ && ( samplerAnisotropy == rhs.samplerAnisotropy )\r
+ && ( textureCompressionETC2 == rhs.textureCompressionETC2 )\r
+ && ( textureCompressionASTC_LDR == rhs.textureCompressionASTC_LDR )\r
+ && ( textureCompressionBC == rhs.textureCompressionBC )\r
+ && ( occlusionQueryPrecise == rhs.occlusionQueryPrecise )\r
+ && ( pipelineStatisticsQuery == rhs.pipelineStatisticsQuery )\r
+ && ( vertexPipelineStoresAndAtomics == rhs.vertexPipelineStoresAndAtomics )\r
+ && ( fragmentStoresAndAtomics == rhs.fragmentStoresAndAtomics )\r
+ && ( shaderTessellationAndGeometryPointSize == rhs.shaderTessellationAndGeometryPointSize )\r
+ && ( shaderImageGatherExtended == rhs.shaderImageGatherExtended )\r
+ && ( shaderStorageImageExtendedFormats == rhs.shaderStorageImageExtendedFormats )\r
+ && ( shaderStorageImageMultisample == rhs.shaderStorageImageMultisample )\r
+ && ( shaderStorageImageReadWithoutFormat == rhs.shaderStorageImageReadWithoutFormat )\r
+ && ( shaderStorageImageWriteWithoutFormat == rhs.shaderStorageImageWriteWithoutFormat )\r
+ && ( shaderUniformBufferArrayDynamicIndexing == rhs.shaderUniformBufferArrayDynamicIndexing )\r
+ && ( shaderSampledImageArrayDynamicIndexing == rhs.shaderSampledImageArrayDynamicIndexing )\r
+ && ( shaderStorageBufferArrayDynamicIndexing == rhs.shaderStorageBufferArrayDynamicIndexing )\r
+ && ( shaderStorageImageArrayDynamicIndexing == rhs.shaderStorageImageArrayDynamicIndexing )\r
+ && ( shaderClipDistance == rhs.shaderClipDistance )\r
+ && ( shaderCullDistance == rhs.shaderCullDistance )\r
+ && ( shaderFloat64 == rhs.shaderFloat64 )\r
+ && ( shaderInt64 == rhs.shaderInt64 )\r
+ && ( shaderInt16 == rhs.shaderInt16 )\r
+ && ( shaderResourceResidency == rhs.shaderResourceResidency )\r
+ && ( shaderResourceMinLod == rhs.shaderResourceMinLod )\r
+ && ( sparseBinding == rhs.sparseBinding )\r
+ && ( sparseResidencyBuffer == rhs.sparseResidencyBuffer )\r
+ && ( sparseResidencyImage2D == rhs.sparseResidencyImage2D )\r
+ && ( sparseResidencyImage3D == rhs.sparseResidencyImage3D )\r
+ && ( sparseResidency2Samples == rhs.sparseResidency2Samples )\r
+ && ( sparseResidency4Samples == rhs.sparseResidency4Samples )\r
+ && ( sparseResidency8Samples == rhs.sparseResidency8Samples )\r
+ && ( sparseResidency16Samples == rhs.sparseResidency16Samples )\r
+ && ( sparseResidencyAliased == rhs.sparseResidencyAliased )\r
+ && ( variableMultisampleRate == rhs.variableMultisampleRate )\r
+ && ( inheritedQueries == rhs.inheritedQueries );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Bool32 robustBufferAccess;\r
+ Bool32 fullDrawIndexUint32;\r
+ Bool32 imageCubeArray;\r
+ Bool32 independentBlend;\r
+ Bool32 geometryShader;\r
+ Bool32 tessellationShader;\r
+ Bool32 sampleRateShading;\r
+ Bool32 dualSrcBlend;\r
+ Bool32 logicOp;\r
+ Bool32 multiDrawIndirect;\r
+ Bool32 drawIndirectFirstInstance;\r
+ Bool32 depthClamp;\r
+ Bool32 depthBiasClamp;\r
+ Bool32 fillModeNonSolid;\r
+ Bool32 depthBounds;\r
+ Bool32 wideLines;\r
+ Bool32 largePoints;\r
+ Bool32 alphaToOne;\r
+ Bool32 multiViewport;\r
+ Bool32 samplerAnisotropy;\r
+ Bool32 textureCompressionETC2;\r
+ Bool32 textureCompressionASTC_LDR;\r
+ Bool32 textureCompressionBC;\r
+ Bool32 occlusionQueryPrecise;\r
+ Bool32 pipelineStatisticsQuery;\r
+ Bool32 vertexPipelineStoresAndAtomics;\r
+ Bool32 fragmentStoresAndAtomics;\r
+ Bool32 shaderTessellationAndGeometryPointSize;\r
+ Bool32 shaderImageGatherExtended;\r
+ Bool32 shaderStorageImageExtendedFormats;\r
+ Bool32 shaderStorageImageMultisample;\r
+ Bool32 shaderStorageImageReadWithoutFormat;\r
+ Bool32 shaderStorageImageWriteWithoutFormat;\r
+ Bool32 shaderUniformBufferArrayDynamicIndexing;\r
+ Bool32 shaderSampledImageArrayDynamicIndexing;\r
+ Bool32 shaderStorageBufferArrayDynamicIndexing;\r
+ Bool32 shaderStorageImageArrayDynamicIndexing;\r
+ Bool32 shaderClipDistance;\r
+ Bool32 shaderCullDistance;\r
+ Bool32 shaderFloat64;\r
+ Bool32 shaderInt64;\r
+ Bool32 shaderInt16;\r
+ Bool32 shaderResourceResidency;\r
+ Bool32 shaderResourceMinLod;\r
+ Bool32 sparseBinding;\r
+ Bool32 sparseResidencyBuffer;\r
+ Bool32 sparseResidencyImage2D;\r
+ Bool32 sparseResidencyImage3D;\r
+ Bool32 sparseResidency2Samples;\r
+ Bool32 sparseResidency4Samples;\r
+ Bool32 sparseResidency8Samples;\r
+ Bool32 sparseResidency16Samples;\r
+ Bool32 sparseResidencyAliased;\r
+ Bool32 variableMultisampleRate;\r
+ Bool32 inheritedQueries;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceFeatures ) == sizeof( VkPhysicalDeviceFeatures ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceSparseProperties\r
+ {\r
+ operator const VkPhysicalDeviceSparseProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSparseProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSparseProperties const& rhs ) const\r
+ {\r
+ return ( residencyStandard2DBlockShape == rhs.residencyStandard2DBlockShape )\r
+ && ( residencyStandard2DMultisampleBlockShape == rhs.residencyStandard2DMultisampleBlockShape )\r
+ && ( residencyStandard3DBlockShape == rhs.residencyStandard3DBlockShape )\r
+ && ( residencyAlignedMipSize == rhs.residencyAlignedMipSize )\r
+ && ( residencyNonResidentStrict == rhs.residencyNonResidentStrict );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSparseProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Bool32 residencyStandard2DBlockShape;\r
+ Bool32 residencyStandard2DMultisampleBlockShape;\r
+ Bool32 residencyStandard3DBlockShape;\r
+ Bool32 residencyAlignedMipSize;\r
+ Bool32 residencyNonResidentStrict;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSparseProperties ) == sizeof( VkPhysicalDeviceSparseProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct DrawIndirectCommand\r
+ {\r
+ DrawIndirectCommand( uint32_t vertexCount_ = 0, uint32_t instanceCount_ = 0, uint32_t firstVertex_ = 0, uint32_t firstInstance_ = 0 )\r
+ : vertexCount( vertexCount_ )\r
+ , instanceCount( instanceCount_ )\r
+ , firstVertex( firstVertex_ )\r
+ , firstInstance( firstInstance_ )\r
+ {\r
+ }\r
+\r
+ DrawIndirectCommand( VkDrawIndirectCommand const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DrawIndirectCommand ) );\r
+ }\r
+\r
+ DrawIndirectCommand& operator=( VkDrawIndirectCommand const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DrawIndirectCommand ) );\r
+ return *this;\r
+ }\r
+ DrawIndirectCommand& setVertexCount( uint32_t vertexCount_ )\r
+ {\r
+ vertexCount = vertexCount_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndirectCommand& setInstanceCount( uint32_t instanceCount_ )\r
+ {\r
+ instanceCount = instanceCount_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndirectCommand& setFirstVertex( uint32_t firstVertex_ )\r
+ {\r
+ firstVertex = firstVertex_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndirectCommand& setFirstInstance( uint32_t firstInstance_ )\r
+ {\r
+ firstInstance = firstInstance_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDrawIndirectCommand&() const\r
+ {\r
+ return *reinterpret_cast<const VkDrawIndirectCommand*>(this);\r
+ }\r
+\r
+ bool operator==( DrawIndirectCommand const& rhs ) const\r
+ {\r
+ return ( vertexCount == rhs.vertexCount )\r
+ && ( instanceCount == rhs.instanceCount )\r
+ && ( firstVertex == rhs.firstVertex )\r
+ && ( firstInstance == rhs.firstInstance );\r
+ }\r
+\r
+ bool operator!=( DrawIndirectCommand const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t vertexCount;\r
+ uint32_t instanceCount;\r
+ uint32_t firstVertex;\r
+ uint32_t firstInstance;\r
+ };\r
+ static_assert( sizeof( DrawIndirectCommand ) == sizeof( VkDrawIndirectCommand ), "struct and wrapper have different size!" );\r
+\r
+ struct DrawIndexedIndirectCommand\r
+ {\r
+ DrawIndexedIndirectCommand( uint32_t indexCount_ = 0, uint32_t instanceCount_ = 0, uint32_t firstIndex_ = 0, int32_t vertexOffset_ = 0, uint32_t firstInstance_ = 0 )\r
+ : indexCount( indexCount_ )\r
+ , instanceCount( instanceCount_ )\r
+ , firstIndex( firstIndex_ )\r
+ , vertexOffset( vertexOffset_ )\r
+ , firstInstance( firstInstance_ )\r
+ {\r
+ }\r
+\r
+ DrawIndexedIndirectCommand( VkDrawIndexedIndirectCommand const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DrawIndexedIndirectCommand ) );\r
+ }\r
+\r
+ DrawIndexedIndirectCommand& operator=( VkDrawIndexedIndirectCommand const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DrawIndexedIndirectCommand ) );\r
+ return *this;\r
+ }\r
+ DrawIndexedIndirectCommand& setIndexCount( uint32_t indexCount_ )\r
+ {\r
+ indexCount = indexCount_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndexedIndirectCommand& setInstanceCount( uint32_t instanceCount_ )\r
+ {\r
+ instanceCount = instanceCount_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndexedIndirectCommand& setFirstIndex( uint32_t firstIndex_ )\r
+ {\r
+ firstIndex = firstIndex_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndexedIndirectCommand& setVertexOffset( int32_t vertexOffset_ )\r
+ {\r
+ vertexOffset = vertexOffset_;\r
+ return *this;\r
+ }\r
+\r
+ DrawIndexedIndirectCommand& setFirstInstance( uint32_t firstInstance_ )\r
+ {\r
+ firstInstance = firstInstance_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDrawIndexedIndirectCommand&() const\r
+ {\r
+ return *reinterpret_cast<const VkDrawIndexedIndirectCommand*>(this);\r
+ }\r
+\r
+ bool operator==( DrawIndexedIndirectCommand const& rhs ) const\r
+ {\r
+ return ( indexCount == rhs.indexCount )\r
+ && ( instanceCount == rhs.instanceCount )\r
+ && ( firstIndex == rhs.firstIndex )\r
+ && ( vertexOffset == rhs.vertexOffset )\r
+ && ( firstInstance == rhs.firstInstance );\r
+ }\r
+\r
+ bool operator!=( DrawIndexedIndirectCommand const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t indexCount;\r
+ uint32_t instanceCount;\r
+ uint32_t firstIndex;\r
+ int32_t vertexOffset;\r
+ uint32_t firstInstance;\r
+ };\r
+ static_assert( sizeof( DrawIndexedIndirectCommand ) == sizeof( VkDrawIndexedIndirectCommand ), "struct and wrapper have different size!" );\r
+\r
+ struct DispatchIndirectCommand\r
+ {\r
+ DispatchIndirectCommand( uint32_t x_ = 0, uint32_t y_ = 0, uint32_t z_ = 0 )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ , z( z_ )\r
+ {\r
+ }\r
+\r
+ DispatchIndirectCommand( VkDispatchIndirectCommand const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DispatchIndirectCommand ) );\r
+ }\r
+\r
+ DispatchIndirectCommand& operator=( VkDispatchIndirectCommand const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DispatchIndirectCommand ) );\r
+ return *this;\r
+ }\r
+ DispatchIndirectCommand& setX( uint32_t x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ DispatchIndirectCommand& setY( uint32_t y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ DispatchIndirectCommand& setZ( uint32_t z_ )\r
+ {\r
+ z = z_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDispatchIndirectCommand&() const\r
+ {\r
+ return *reinterpret_cast<const VkDispatchIndirectCommand*>(this);\r
+ }\r
+\r
+ bool operator==( DispatchIndirectCommand const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y )\r
+ && ( z == rhs.z );\r
+ }\r
+\r
+ bool operator!=( DispatchIndirectCommand const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t x;\r
+ uint32_t y;\r
+ uint32_t z;\r
+ };\r
+ static_assert( sizeof( DispatchIndirectCommand ) == sizeof( VkDispatchIndirectCommand ), "struct and wrapper have different size!" );\r
+\r
+ struct DisplayPlanePropertiesKHR\r
+ {\r
+ operator const VkDisplayPlanePropertiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayPlanePropertiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayPlanePropertiesKHR const& rhs ) const\r
+ {\r
+ return ( currentDisplay == rhs.currentDisplay )\r
+ && ( currentStackIndex == rhs.currentStackIndex );\r
+ }\r
+\r
+ bool operator!=( DisplayPlanePropertiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DisplayKHR currentDisplay;\r
+ uint32_t currentStackIndex;\r
+ };\r
+ static_assert( sizeof( DisplayPlanePropertiesKHR ) == sizeof( VkDisplayPlanePropertiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct DisplayModeParametersKHR\r
+ {\r
+ DisplayModeParametersKHR( Extent2D visibleRegion_ = Extent2D(), uint32_t refreshRate_ = 0 )\r
+ : visibleRegion( visibleRegion_ )\r
+ , refreshRate( refreshRate_ )\r
+ {\r
+ }\r
+\r
+ DisplayModeParametersKHR( VkDisplayModeParametersKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayModeParametersKHR ) );\r
+ }\r
+\r
+ DisplayModeParametersKHR& operator=( VkDisplayModeParametersKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayModeParametersKHR ) );\r
+ return *this;\r
+ }\r
+ DisplayModeParametersKHR& setVisibleRegion( Extent2D visibleRegion_ )\r
+ {\r
+ visibleRegion = visibleRegion_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayModeParametersKHR& setRefreshRate( uint32_t refreshRate_ )\r
+ {\r
+ refreshRate = refreshRate_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDisplayModeParametersKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayModeParametersKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayModeParametersKHR const& rhs ) const\r
+ {\r
+ return ( visibleRegion == rhs.visibleRegion )\r
+ && ( refreshRate == rhs.refreshRate );\r
+ }\r
+\r
+ bool operator!=( DisplayModeParametersKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Extent2D visibleRegion;\r
+ uint32_t refreshRate;\r
+ };\r
+ static_assert( sizeof( DisplayModeParametersKHR ) == sizeof( VkDisplayModeParametersKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct DisplayModePropertiesKHR\r
+ {\r
+ operator const VkDisplayModePropertiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayModePropertiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayModePropertiesKHR const& rhs ) const\r
+ {\r
+ return ( displayMode == rhs.displayMode )\r
+ && ( parameters == rhs.parameters );\r
+ }\r
+\r
+ bool operator!=( DisplayModePropertiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DisplayModeKHR displayMode;\r
+ DisplayModeParametersKHR parameters;\r
+ };\r
+ static_assert( sizeof( DisplayModePropertiesKHR ) == sizeof( VkDisplayModePropertiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct RectLayerKHR\r
+ {\r
+ RectLayerKHR( Offset2D offset_ = Offset2D(), Extent2D extent_ = Extent2D(), uint32_t layer_ = 0 )\r
+ : offset( offset_ )\r
+ , extent( extent_ )\r
+ , layer( layer_ )\r
+ {\r
+ }\r
+\r
+ RectLayerKHR( VkRectLayerKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RectLayerKHR ) );\r
+ }\r
+\r
+ RectLayerKHR& operator=( VkRectLayerKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RectLayerKHR ) );\r
+ return *this;\r
+ }\r
+ RectLayerKHR& setOffset( Offset2D offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ RectLayerKHR& setExtent( Extent2D extent_ )\r
+ {\r
+ extent = extent_;\r
+ return *this;\r
+ }\r
+\r
+ RectLayerKHR& setLayer( uint32_t layer_ )\r
+ {\r
+ layer = layer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRectLayerKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkRectLayerKHR*>(this);\r
+ }\r
+\r
+ bool operator==( RectLayerKHR const& rhs ) const\r
+ {\r
+ return ( offset == rhs.offset )\r
+ && ( extent == rhs.extent )\r
+ && ( layer == rhs.layer );\r
+ }\r
+\r
+ bool operator!=( RectLayerKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Offset2D offset;\r
+ Extent2D extent;\r
+ uint32_t layer;\r
+ };\r
+ static_assert( sizeof( RectLayerKHR ) == sizeof( VkRectLayerKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct PresentRegionKHR\r
+ {\r
+ PresentRegionKHR( uint32_t rectangleCount_ = 0, const RectLayerKHR* pRectangles_ = nullptr )\r
+ : rectangleCount( rectangleCount_ )\r
+ , pRectangles( pRectangles_ )\r
+ {\r
+ }\r
+\r
+ PresentRegionKHR( VkPresentRegionKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentRegionKHR ) );\r
+ }\r
+\r
+ PresentRegionKHR& operator=( VkPresentRegionKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentRegionKHR ) );\r
+ return *this;\r
+ }\r
+ PresentRegionKHR& setRectangleCount( uint32_t rectangleCount_ )\r
+ {\r
+ rectangleCount = rectangleCount_;\r
+ return *this;\r
+ }\r
+\r
+ PresentRegionKHR& setPRectangles( const RectLayerKHR* pRectangles_ )\r
+ {\r
+ pRectangles = pRectangles_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPresentRegionKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkPresentRegionKHR*>(this);\r
+ }\r
+\r
+ bool operator==( PresentRegionKHR const& rhs ) const\r
+ {\r
+ return ( rectangleCount == rhs.rectangleCount )\r
+ && ( pRectangles == rhs.pRectangles );\r
+ }\r
+\r
+ bool operator!=( PresentRegionKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t rectangleCount;\r
+ const RectLayerKHR* pRectangles;\r
+ };\r
+ static_assert( sizeof( PresentRegionKHR ) == sizeof( VkPresentRegionKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct XYColorEXT\r
+ {\r
+ XYColorEXT( float x_ = 0, float y_ = 0 )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ {\r
+ }\r
+\r
+ XYColorEXT( VkXYColorEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( XYColorEXT ) );\r
+ }\r
+\r
+ XYColorEXT& operator=( VkXYColorEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( XYColorEXT ) );\r
+ return *this;\r
+ }\r
+ XYColorEXT& setX( float x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ XYColorEXT& setY( float y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkXYColorEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkXYColorEXT*>(this);\r
+ }\r
+\r
+ bool operator==( XYColorEXT const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y );\r
+ }\r
+\r
+ bool operator!=( XYColorEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ float x;\r
+ float y;\r
+ };\r
+ static_assert( sizeof( XYColorEXT ) == sizeof( VkXYColorEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct RefreshCycleDurationGOOGLE\r
+ {\r
+ RefreshCycleDurationGOOGLE( uint64_t refreshDuration_ = 0 )\r
+ : refreshDuration( refreshDuration_ )\r
+ {\r
+ }\r
+\r
+ RefreshCycleDurationGOOGLE( VkRefreshCycleDurationGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RefreshCycleDurationGOOGLE ) );\r
+ }\r
+\r
+ RefreshCycleDurationGOOGLE& operator=( VkRefreshCycleDurationGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RefreshCycleDurationGOOGLE ) );\r
+ return *this;\r
+ }\r
+ RefreshCycleDurationGOOGLE& setRefreshDuration( uint64_t refreshDuration_ )\r
+ {\r
+ refreshDuration = refreshDuration_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRefreshCycleDurationGOOGLE&() const\r
+ {\r
+ return *reinterpret_cast<const VkRefreshCycleDurationGOOGLE*>(this);\r
+ }\r
+\r
+ bool operator==( RefreshCycleDurationGOOGLE const& rhs ) const\r
+ {\r
+ return ( refreshDuration == rhs.refreshDuration );\r
+ }\r
+\r
+ bool operator!=( RefreshCycleDurationGOOGLE const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint64_t refreshDuration;\r
+ };\r
+ static_assert( sizeof( RefreshCycleDurationGOOGLE ) == sizeof( VkRefreshCycleDurationGOOGLE ), "struct and wrapper have different size!" );\r
+\r
+ struct PastPresentationTimingGOOGLE\r
+ {\r
+ PastPresentationTimingGOOGLE( uint32_t presentID_ = 0, uint64_t desiredPresentTime_ = 0, uint64_t actualPresentTime_ = 0, uint64_t earliestPresentTime_ = 0, uint64_t presentMargin_ = 0 )\r
+ : presentID( presentID_ )\r
+ , desiredPresentTime( desiredPresentTime_ )\r
+ , actualPresentTime( actualPresentTime_ )\r
+ , earliestPresentTime( earliestPresentTime_ )\r
+ , presentMargin( presentMargin_ )\r
+ {\r
+ }\r
+\r
+ PastPresentationTimingGOOGLE( VkPastPresentationTimingGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PastPresentationTimingGOOGLE ) );\r
+ }\r
+\r
+ PastPresentationTimingGOOGLE& operator=( VkPastPresentationTimingGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PastPresentationTimingGOOGLE ) );\r
+ return *this;\r
+ }\r
+ PastPresentationTimingGOOGLE& setPresentID( uint32_t presentID_ )\r
+ {\r
+ presentID = presentID_;\r
+ return *this;\r
+ }\r
+\r
+ PastPresentationTimingGOOGLE& setDesiredPresentTime( uint64_t desiredPresentTime_ )\r
+ {\r
+ desiredPresentTime = desiredPresentTime_;\r
+ return *this;\r
+ }\r
+\r
+ PastPresentationTimingGOOGLE& setActualPresentTime( uint64_t actualPresentTime_ )\r
+ {\r
+ actualPresentTime = actualPresentTime_;\r
+ return *this;\r
+ }\r
+\r
+ PastPresentationTimingGOOGLE& setEarliestPresentTime( uint64_t earliestPresentTime_ )\r
+ {\r
+ earliestPresentTime = earliestPresentTime_;\r
+ return *this;\r
+ }\r
+\r
+ PastPresentationTimingGOOGLE& setPresentMargin( uint64_t presentMargin_ )\r
+ {\r
+ presentMargin = presentMargin_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPastPresentationTimingGOOGLE&() const\r
+ {\r
+ return *reinterpret_cast<const VkPastPresentationTimingGOOGLE*>(this);\r
+ }\r
+\r
+ bool operator==( PastPresentationTimingGOOGLE const& rhs ) const\r
+ {\r
+ return ( presentID == rhs.presentID )\r
+ && ( desiredPresentTime == rhs.desiredPresentTime )\r
+ && ( actualPresentTime == rhs.actualPresentTime )\r
+ && ( earliestPresentTime == rhs.earliestPresentTime )\r
+ && ( presentMargin == rhs.presentMargin );\r
+ }\r
+\r
+ bool operator!=( PastPresentationTimingGOOGLE const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t presentID;\r
+ uint64_t desiredPresentTime;\r
+ uint64_t actualPresentTime;\r
+ uint64_t earliestPresentTime;\r
+ uint64_t presentMargin;\r
+ };\r
+ static_assert( sizeof( PastPresentationTimingGOOGLE ) == sizeof( VkPastPresentationTimingGOOGLE ), "struct and wrapper have different size!" );\r
+\r
+ struct PresentTimeGOOGLE\r
+ {\r
+ PresentTimeGOOGLE( uint32_t presentID_ = 0, uint64_t desiredPresentTime_ = 0 )\r
+ : presentID( presentID_ )\r
+ , desiredPresentTime( desiredPresentTime_ )\r
+ {\r
+ }\r
+\r
+ PresentTimeGOOGLE( VkPresentTimeGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentTimeGOOGLE ) );\r
+ }\r
+\r
+ PresentTimeGOOGLE& operator=( VkPresentTimeGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentTimeGOOGLE ) );\r
+ return *this;\r
+ }\r
+ PresentTimeGOOGLE& setPresentID( uint32_t presentID_ )\r
+ {\r
+ presentID = presentID_;\r
+ return *this;\r
+ }\r
+\r
+ PresentTimeGOOGLE& setDesiredPresentTime( uint64_t desiredPresentTime_ )\r
+ {\r
+ desiredPresentTime = desiredPresentTime_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPresentTimeGOOGLE&() const\r
+ {\r
+ return *reinterpret_cast<const VkPresentTimeGOOGLE*>(this);\r
+ }\r
+\r
+ bool operator==( PresentTimeGOOGLE const& rhs ) const\r
+ {\r
+ return ( presentID == rhs.presentID )\r
+ && ( desiredPresentTime == rhs.desiredPresentTime );\r
+ }\r
+\r
+ bool operator!=( PresentTimeGOOGLE const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t presentID;\r
+ uint64_t desiredPresentTime;\r
+ };\r
+ static_assert( sizeof( PresentTimeGOOGLE ) == sizeof( VkPresentTimeGOOGLE ), "struct and wrapper have different size!" );\r
+\r
+ struct ViewportWScalingNV\r
+ {\r
+ ViewportWScalingNV( float xcoeff_ = 0, float ycoeff_ = 0 )\r
+ : xcoeff( xcoeff_ )\r
+ , ycoeff( ycoeff_ )\r
+ {\r
+ }\r
+\r
+ ViewportWScalingNV( VkViewportWScalingNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ViewportWScalingNV ) );\r
+ }\r
+\r
+ ViewportWScalingNV& operator=( VkViewportWScalingNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ViewportWScalingNV ) );\r
+ return *this;\r
+ }\r
+ ViewportWScalingNV& setXcoeff( float xcoeff_ )\r
+ {\r
+ xcoeff = xcoeff_;\r
+ return *this;\r
+ }\r
+\r
+ ViewportWScalingNV& setYcoeff( float ycoeff_ )\r
+ {\r
+ ycoeff = ycoeff_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkViewportWScalingNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkViewportWScalingNV*>(this);\r
+ }\r
+\r
+ bool operator==( ViewportWScalingNV const& rhs ) const\r
+ {\r
+ return ( xcoeff == rhs.xcoeff )\r
+ && ( ycoeff == rhs.ycoeff );\r
+ }\r
+\r
+ bool operator!=( ViewportWScalingNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ float xcoeff;\r
+ float ycoeff;\r
+ };\r
+ static_assert( sizeof( ViewportWScalingNV ) == sizeof( VkViewportWScalingNV ), "struct and wrapper have different size!" );\r
+\r
+ struct SampleLocationEXT\r
+ {\r
+ SampleLocationEXT( float x_ = 0, float y_ = 0 )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ {\r
+ }\r
+\r
+ SampleLocationEXT( VkSampleLocationEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SampleLocationEXT ) );\r
+ }\r
+\r
+ SampleLocationEXT& operator=( VkSampleLocationEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SampleLocationEXT ) );\r
+ return *this;\r
+ }\r
+ SampleLocationEXT& setX( float x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ SampleLocationEXT& setY( float y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSampleLocationEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkSampleLocationEXT*>(this);\r
+ }\r
+\r
+ bool operator==( SampleLocationEXT const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y );\r
+ }\r
+\r
+ bool operator!=( SampleLocationEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ float x;\r
+ float y;\r
+ };\r
+ static_assert( sizeof( SampleLocationEXT ) == sizeof( VkSampleLocationEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct ShaderResourceUsageAMD\r
+ {\r
+ operator const VkShaderResourceUsageAMD&() const\r
+ {\r
+ return *reinterpret_cast<const VkShaderResourceUsageAMD*>(this);\r
+ }\r
+\r
+ bool operator==( ShaderResourceUsageAMD const& rhs ) const\r
+ {\r
+ return ( numUsedVgprs == rhs.numUsedVgprs )\r
+ && ( numUsedSgprs == rhs.numUsedSgprs )\r
+ && ( ldsSizePerLocalWorkGroup == rhs.ldsSizePerLocalWorkGroup )\r
+ && ( ldsUsageSizeInBytes == rhs.ldsUsageSizeInBytes )\r
+ && ( scratchMemUsageInBytes == rhs.scratchMemUsageInBytes );\r
+ }\r
+\r
+ bool operator!=( ShaderResourceUsageAMD const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t numUsedVgprs;\r
+ uint32_t numUsedSgprs;\r
+ uint32_t ldsSizePerLocalWorkGroup;\r
+ size_t ldsUsageSizeInBytes;\r
+ size_t scratchMemUsageInBytes;\r
+ };\r
+ static_assert( sizeof( ShaderResourceUsageAMD ) == sizeof( VkShaderResourceUsageAMD ), "struct and wrapper have different size!" );\r
+\r
+ struct VertexInputBindingDivisorDescriptionEXT\r
+ {\r
+ VertexInputBindingDivisorDescriptionEXT( uint32_t binding_ = 0, uint32_t divisor_ = 0 )\r
+ : binding( binding_ )\r
+ , divisor( divisor_ )\r
+ {\r
+ }\r
+\r
+ VertexInputBindingDivisorDescriptionEXT( VkVertexInputBindingDivisorDescriptionEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( VertexInputBindingDivisorDescriptionEXT ) );\r
+ }\r
+\r
+ VertexInputBindingDivisorDescriptionEXT& operator=( VkVertexInputBindingDivisorDescriptionEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( VertexInputBindingDivisorDescriptionEXT ) );\r
+ return *this;\r
+ }\r
+ VertexInputBindingDivisorDescriptionEXT& setBinding( uint32_t binding_ )\r
+ {\r
+ binding = binding_;\r
+ return *this;\r
+ }\r
+\r
+ VertexInputBindingDivisorDescriptionEXT& setDivisor( uint32_t divisor_ )\r
+ {\r
+ divisor = divisor_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkVertexInputBindingDivisorDescriptionEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkVertexInputBindingDivisorDescriptionEXT*>(this);\r
+ }\r
+\r
+ bool operator==( VertexInputBindingDivisorDescriptionEXT const& rhs ) const\r
+ {\r
+ return ( binding == rhs.binding )\r
+ && ( divisor == rhs.divisor );\r
+ }\r
+\r
+ bool operator!=( VertexInputBindingDivisorDescriptionEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t binding;\r
+ uint32_t divisor;\r
+ };\r
+ static_assert( sizeof( VertexInputBindingDivisorDescriptionEXT ) == sizeof( VkVertexInputBindingDivisorDescriptionEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class ImageLayout\r
+ {\r
+ eUndefined = VK_IMAGE_LAYOUT_UNDEFINED,\r
+ eGeneral = VK_IMAGE_LAYOUT_GENERAL,\r
+ eColorAttachmentOptimal = VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL,\r
+ eDepthStencilAttachmentOptimal = VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL,\r
+ eDepthStencilReadOnlyOptimal = VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL,\r
+ eShaderReadOnlyOptimal = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL,\r
+ eTransferSrcOptimal = VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL,\r
+ eTransferDstOptimal = VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,\r
+ ePreinitialized = VK_IMAGE_LAYOUT_PREINITIALIZED,\r
+ eDepthReadOnlyStencilAttachmentOptimal = VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL,\r
+ eDepthReadOnlyStencilAttachmentOptimalKHR = VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL,\r
+ eDepthAttachmentStencilReadOnlyOptimal = VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL,\r
+ eDepthAttachmentStencilReadOnlyOptimalKHR = VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL,\r
+ ePresentSrcKHR = VK_IMAGE_LAYOUT_PRESENT_SRC_KHR,\r
+ eSharedPresentKHR = VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR\r
+ };\r
+\r
+ struct DescriptorImageInfo\r
+ {\r
+ DescriptorImageInfo( Sampler sampler_ = Sampler(), ImageView imageView_ = ImageView(), ImageLayout imageLayout_ = ImageLayout::eUndefined )\r
+ : sampler( sampler_ )\r
+ , imageView( imageView_ )\r
+ , imageLayout( imageLayout_ )\r
+ {\r
+ }\r
+\r
+ DescriptorImageInfo( VkDescriptorImageInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorImageInfo ) );\r
+ }\r
+\r
+ DescriptorImageInfo& operator=( VkDescriptorImageInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorImageInfo ) );\r
+ return *this;\r
+ }\r
+ DescriptorImageInfo& setSampler( Sampler sampler_ )\r
+ {\r
+ sampler = sampler_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorImageInfo& setImageView( ImageView imageView_ )\r
+ {\r
+ imageView = imageView_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorImageInfo& setImageLayout( ImageLayout imageLayout_ )\r
+ {\r
+ imageLayout = imageLayout_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorImageInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorImageInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorImageInfo const& rhs ) const\r
+ {\r
+ return ( sampler == rhs.sampler )\r
+ && ( imageView == rhs.imageView )\r
+ && ( imageLayout == rhs.imageLayout );\r
+ }\r
+\r
+ bool operator!=( DescriptorImageInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Sampler sampler;\r
+ ImageView imageView;\r
+ ImageLayout imageLayout;\r
+ };\r
+ static_assert( sizeof( DescriptorImageInfo ) == sizeof( VkDescriptorImageInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct AttachmentReference\r
+ {\r
+ AttachmentReference( uint32_t attachment_ = 0, ImageLayout layout_ = ImageLayout::eUndefined )\r
+ : attachment( attachment_ )\r
+ , layout( layout_ )\r
+ {\r
+ }\r
+\r
+ AttachmentReference( VkAttachmentReference const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AttachmentReference ) );\r
+ }\r
+\r
+ AttachmentReference& operator=( VkAttachmentReference const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AttachmentReference ) );\r
+ return *this;\r
+ }\r
+ AttachmentReference& setAttachment( uint32_t attachment_ )\r
+ {\r
+ attachment = attachment_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentReference& setLayout( ImageLayout layout_ )\r
+ {\r
+ layout = layout_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkAttachmentReference&() const\r
+ {\r
+ return *reinterpret_cast<const VkAttachmentReference*>(this);\r
+ }\r
+\r
+ bool operator==( AttachmentReference const& rhs ) const\r
+ {\r
+ return ( attachment == rhs.attachment )\r
+ && ( layout == rhs.layout );\r
+ }\r
+\r
+ bool operator!=( AttachmentReference const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t attachment;\r
+ ImageLayout layout;\r
+ };\r
+ static_assert( sizeof( AttachmentReference ) == sizeof( VkAttachmentReference ), "struct and wrapper have different size!" );\r
+\r
+ enum class AttachmentLoadOp\r
+ {\r
+ eLoad = VK_ATTACHMENT_LOAD_OP_LOAD,\r
+ eClear = VK_ATTACHMENT_LOAD_OP_CLEAR,\r
+ eDontCare = VK_ATTACHMENT_LOAD_OP_DONT_CARE\r
+ };\r
+\r
+ enum class AttachmentStoreOp\r
+ {\r
+ eStore = VK_ATTACHMENT_STORE_OP_STORE,\r
+ eDontCare = VK_ATTACHMENT_STORE_OP_DONT_CARE\r
+ };\r
+\r
+ enum class ImageType\r
+ {\r
+ e1D = VK_IMAGE_TYPE_1D,\r
+ e2D = VK_IMAGE_TYPE_2D,\r
+ e3D = VK_IMAGE_TYPE_3D\r
+ };\r
+\r
+ enum class ImageTiling\r
+ {\r
+ eOptimal = VK_IMAGE_TILING_OPTIMAL,\r
+ eLinear = VK_IMAGE_TILING_LINEAR\r
+ };\r
+\r
+ enum class ImageViewType\r
+ {\r
+ e1D = VK_IMAGE_VIEW_TYPE_1D,\r
+ e2D = VK_IMAGE_VIEW_TYPE_2D,\r
+ e3D = VK_IMAGE_VIEW_TYPE_3D,\r
+ eCube = VK_IMAGE_VIEW_TYPE_CUBE,\r
+ e1DArray = VK_IMAGE_VIEW_TYPE_1D_ARRAY,\r
+ e2DArray = VK_IMAGE_VIEW_TYPE_2D_ARRAY,\r
+ eCubeArray = VK_IMAGE_VIEW_TYPE_CUBE_ARRAY\r
+ };\r
+\r
+ enum class CommandBufferLevel\r
+ {\r
+ ePrimary = VK_COMMAND_BUFFER_LEVEL_PRIMARY,\r
+ eSecondary = VK_COMMAND_BUFFER_LEVEL_SECONDARY\r
+ };\r
+\r
+ enum class ComponentSwizzle\r
+ {\r
+ eIdentity = VK_COMPONENT_SWIZZLE_IDENTITY,\r
+ eZero = VK_COMPONENT_SWIZZLE_ZERO,\r
+ eOne = VK_COMPONENT_SWIZZLE_ONE,\r
+ eR = VK_COMPONENT_SWIZZLE_R,\r
+ eG = VK_COMPONENT_SWIZZLE_G,\r
+ eB = VK_COMPONENT_SWIZZLE_B,\r
+ eA = VK_COMPONENT_SWIZZLE_A\r
+ };\r
+\r
+ struct ComponentMapping\r
+ {\r
+ ComponentMapping( ComponentSwizzle r_ = ComponentSwizzle::eIdentity, ComponentSwizzle g_ = ComponentSwizzle::eIdentity, ComponentSwizzle b_ = ComponentSwizzle::eIdentity, ComponentSwizzle a_ = ComponentSwizzle::eIdentity )\r
+ : r( r_ )\r
+ , g( g_ )\r
+ , b( b_ )\r
+ , a( a_ )\r
+ {\r
+ }\r
+\r
+ ComponentMapping( VkComponentMapping const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ComponentMapping ) );\r
+ }\r
+\r
+ ComponentMapping& operator=( VkComponentMapping const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ComponentMapping ) );\r
+ return *this;\r
+ }\r
+ ComponentMapping& setR( ComponentSwizzle r_ )\r
+ {\r
+ r = r_;\r
+ return *this;\r
+ }\r
+\r
+ ComponentMapping& setG( ComponentSwizzle g_ )\r
+ {\r
+ g = g_;\r
+ return *this;\r
+ }\r
+\r
+ ComponentMapping& setB( ComponentSwizzle b_ )\r
+ {\r
+ b = b_;\r
+ return *this;\r
+ }\r
+\r
+ ComponentMapping& setA( ComponentSwizzle a_ )\r
+ {\r
+ a = a_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkComponentMapping&() const\r
+ {\r
+ return *reinterpret_cast<const VkComponentMapping*>(this);\r
+ }\r
+\r
+ bool operator==( ComponentMapping const& rhs ) const\r
+ {\r
+ return ( r == rhs.r )\r
+ && ( g == rhs.g )\r
+ && ( b == rhs.b )\r
+ && ( a == rhs.a );\r
+ }\r
+\r
+ bool operator!=( ComponentMapping const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ComponentSwizzle r;\r
+ ComponentSwizzle g;\r
+ ComponentSwizzle b;\r
+ ComponentSwizzle a;\r
+ };\r
+ static_assert( sizeof( ComponentMapping ) == sizeof( VkComponentMapping ), "struct and wrapper have different size!" );\r
+\r
+ enum class DescriptorType\r
+ {\r
+ eSampler = VK_DESCRIPTOR_TYPE_SAMPLER,\r
+ eCombinedImageSampler = VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,\r
+ eSampledImage = VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,\r
+ eStorageImage = VK_DESCRIPTOR_TYPE_STORAGE_IMAGE,\r
+ eUniformTexelBuffer = VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER,\r
+ eStorageTexelBuffer = VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER,\r
+ eUniformBuffer = VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,\r
+ eStorageBuffer = VK_DESCRIPTOR_TYPE_STORAGE_BUFFER,\r
+ eUniformBufferDynamic = VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC,\r
+ eStorageBufferDynamic = VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC,\r
+ eInputAttachment = VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT\r
+ };\r
+\r
+ struct DescriptorPoolSize\r
+ {\r
+ DescriptorPoolSize( DescriptorType type_ = DescriptorType::eSampler, uint32_t descriptorCount_ = 0 )\r
+ : type( type_ )\r
+ , descriptorCount( descriptorCount_ )\r
+ {\r
+ }\r
+\r
+ DescriptorPoolSize( VkDescriptorPoolSize const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorPoolSize ) );\r
+ }\r
+\r
+ DescriptorPoolSize& operator=( VkDescriptorPoolSize const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorPoolSize ) );\r
+ return *this;\r
+ }\r
+ DescriptorPoolSize& setType( DescriptorType type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorPoolSize& setDescriptorCount( uint32_t descriptorCount_ )\r
+ {\r
+ descriptorCount = descriptorCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorPoolSize&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorPoolSize*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorPoolSize const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( descriptorCount == rhs.descriptorCount );\r
+ }\r
+\r
+ bool operator!=( DescriptorPoolSize const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DescriptorType type;\r
+ uint32_t descriptorCount;\r
+ };\r
+ static_assert( sizeof( DescriptorPoolSize ) == sizeof( VkDescriptorPoolSize ), "struct and wrapper have different size!" );\r
+\r
+ struct DescriptorUpdateTemplateEntry\r
+ {\r
+ DescriptorUpdateTemplateEntry( uint32_t dstBinding_ = 0, uint32_t dstArrayElement_ = 0, uint32_t descriptorCount_ = 0, DescriptorType descriptorType_ = DescriptorType::eSampler, size_t offset_ = 0, size_t stride_ = 0 )\r
+ : dstBinding( dstBinding_ )\r
+ , dstArrayElement( dstArrayElement_ )\r
+ , descriptorCount( descriptorCount_ )\r
+ , descriptorType( descriptorType_ )\r
+ , offset( offset_ )\r
+ , stride( stride_ )\r
+ {\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry( VkDescriptorUpdateTemplateEntry const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorUpdateTemplateEntry ) );\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry& operator=( VkDescriptorUpdateTemplateEntry const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorUpdateTemplateEntry ) );\r
+ return *this;\r
+ }\r
+ DescriptorUpdateTemplateEntry& setDstBinding( uint32_t dstBinding_ )\r
+ {\r
+ dstBinding = dstBinding_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry& setDstArrayElement( uint32_t dstArrayElement_ )\r
+ {\r
+ dstArrayElement = dstArrayElement_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry& setDescriptorCount( uint32_t descriptorCount_ )\r
+ {\r
+ descriptorCount = descriptorCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry& setDescriptorType( DescriptorType descriptorType_ )\r
+ {\r
+ descriptorType = descriptorType_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry& setOffset( size_t offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateEntry& setStride( size_t stride_ )\r
+ {\r
+ stride = stride_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorUpdateTemplateEntry&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorUpdateTemplateEntry*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorUpdateTemplateEntry const& rhs ) const\r
+ {\r
+ return ( dstBinding == rhs.dstBinding )\r
+ && ( dstArrayElement == rhs.dstArrayElement )\r
+ && ( descriptorCount == rhs.descriptorCount )\r
+ && ( descriptorType == rhs.descriptorType )\r
+ && ( offset == rhs.offset )\r
+ && ( stride == rhs.stride );\r
+ }\r
+\r
+ bool operator!=( DescriptorUpdateTemplateEntry const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t dstBinding;\r
+ uint32_t dstArrayElement;\r
+ uint32_t descriptorCount;\r
+ DescriptorType descriptorType;\r
+ size_t offset;\r
+ size_t stride;\r
+ };\r
+ static_assert( sizeof( DescriptorUpdateTemplateEntry ) == sizeof( VkDescriptorUpdateTemplateEntry ), "struct and wrapper have different size!" );\r
+\r
+ using DescriptorUpdateTemplateEntryKHR = DescriptorUpdateTemplateEntry;\r
+\r
+ enum class QueryType\r
+ {\r
+ eOcclusion = VK_QUERY_TYPE_OCCLUSION,\r
+ ePipelineStatistics = VK_QUERY_TYPE_PIPELINE_STATISTICS,\r
+ eTimestamp = VK_QUERY_TYPE_TIMESTAMP\r
+ };\r
+\r
+ enum class BorderColor\r
+ {\r
+ eFloatTransparentBlack = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK,\r
+ eIntTransparentBlack = VK_BORDER_COLOR_INT_TRANSPARENT_BLACK,\r
+ eFloatOpaqueBlack = VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK,\r
+ eIntOpaqueBlack = VK_BORDER_COLOR_INT_OPAQUE_BLACK,\r
+ eFloatOpaqueWhite = VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE,\r
+ eIntOpaqueWhite = VK_BORDER_COLOR_INT_OPAQUE_WHITE\r
+ };\r
+\r
+ enum class PipelineBindPoint\r
+ {\r
+ eGraphics = VK_PIPELINE_BIND_POINT_GRAPHICS,\r
+ eCompute = VK_PIPELINE_BIND_POINT_COMPUTE\r
+ };\r
+\r
+ enum class PipelineCacheHeaderVersion\r
+ {\r
+ eOne = VK_PIPELINE_CACHE_HEADER_VERSION_ONE\r
+ };\r
+\r
+ enum class PrimitiveTopology\r
+ {\r
+ ePointList = VK_PRIMITIVE_TOPOLOGY_POINT_LIST,\r
+ eLineList = VK_PRIMITIVE_TOPOLOGY_LINE_LIST,\r
+ eLineStrip = VK_PRIMITIVE_TOPOLOGY_LINE_STRIP,\r
+ eTriangleList = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST,\r
+ eTriangleStrip = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP,\r
+ eTriangleFan = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_FAN,\r
+ eLineListWithAdjacency = VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY,\r
+ eLineStripWithAdjacency = VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY,\r
+ eTriangleListWithAdjacency = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY,\r
+ eTriangleStripWithAdjacency = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY,\r
+ ePatchList = VK_PRIMITIVE_TOPOLOGY_PATCH_LIST\r
+ };\r
+\r
+ enum class SharingMode\r
+ {\r
+ eExclusive = VK_SHARING_MODE_EXCLUSIVE,\r
+ eConcurrent = VK_SHARING_MODE_CONCURRENT\r
+ };\r
+\r
+ enum class IndexType\r
+ {\r
+ eUint16 = VK_INDEX_TYPE_UINT16,\r
+ eUint32 = VK_INDEX_TYPE_UINT32\r
+ };\r
+\r
+ enum class Filter\r
+ {\r
+ eNearest = VK_FILTER_NEAREST,\r
+ eLinear = VK_FILTER_LINEAR,\r
+ eCubicIMG = VK_FILTER_CUBIC_IMG\r
+ };\r
+\r
+ enum class SamplerMipmapMode\r
+ {\r
+ eNearest = VK_SAMPLER_MIPMAP_MODE_NEAREST,\r
+ eLinear = VK_SAMPLER_MIPMAP_MODE_LINEAR\r
+ };\r
+\r
+ enum class SamplerAddressMode\r
+ {\r
+ eRepeat = VK_SAMPLER_ADDRESS_MODE_REPEAT,\r
+ eMirroredRepeat = VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT,\r
+ eClampToEdge = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE,\r
+ eClampToBorder = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER,\r
+ eMirrorClampToEdge = VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE\r
+ };\r
+\r
+ enum class CompareOp\r
+ {\r
+ eNever = VK_COMPARE_OP_NEVER,\r
+ eLess = VK_COMPARE_OP_LESS,\r
+ eEqual = VK_COMPARE_OP_EQUAL,\r
+ eLessOrEqual = VK_COMPARE_OP_LESS_OR_EQUAL,\r
+ eGreater = VK_COMPARE_OP_GREATER,\r
+ eNotEqual = VK_COMPARE_OP_NOT_EQUAL,\r
+ eGreaterOrEqual = VK_COMPARE_OP_GREATER_OR_EQUAL,\r
+ eAlways = VK_COMPARE_OP_ALWAYS\r
+ };\r
+\r
+ enum class PolygonMode\r
+ {\r
+ eFill = VK_POLYGON_MODE_FILL,\r
+ eLine = VK_POLYGON_MODE_LINE,\r
+ ePoint = VK_POLYGON_MODE_POINT,\r
+ eFillRectangleNV = VK_POLYGON_MODE_FILL_RECTANGLE_NV\r
+ };\r
+\r
+ enum class CullModeFlagBits\r
+ {\r
+ eNone = VK_CULL_MODE_NONE,\r
+ eFront = VK_CULL_MODE_FRONT_BIT,\r
+ eBack = VK_CULL_MODE_BACK_BIT,\r
+ eFrontAndBack = VK_CULL_MODE_FRONT_AND_BACK\r
+ };\r
+\r
+ using CullModeFlags = Flags<CullModeFlagBits, VkCullModeFlags>;\r
+\r
+ VULKAN_HPP_INLINE CullModeFlags operator|( CullModeFlagBits bit0, CullModeFlagBits bit1 )\r
+ {\r
+ return CullModeFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE CullModeFlags operator~( CullModeFlagBits bits )\r
+ {\r
+ return ~( CullModeFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<CullModeFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(CullModeFlagBits::eNone) | VkFlags(CullModeFlagBits::eFront) | VkFlags(CullModeFlagBits::eBack) | VkFlags(CullModeFlagBits::eFrontAndBack)\r
+ };\r
+ };\r
+\r
+ enum class FrontFace\r
+ {\r
+ eCounterClockwise = VK_FRONT_FACE_COUNTER_CLOCKWISE,\r
+ eClockwise = VK_FRONT_FACE_CLOCKWISE\r
+ };\r
+\r
+ enum class BlendFactor\r
+ {\r
+ eZero = VK_BLEND_FACTOR_ZERO,\r
+ eOne = VK_BLEND_FACTOR_ONE,\r
+ eSrcColor = VK_BLEND_FACTOR_SRC_COLOR,\r
+ eOneMinusSrcColor = VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR,\r
+ eDstColor = VK_BLEND_FACTOR_DST_COLOR,\r
+ eOneMinusDstColor = VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR,\r
+ eSrcAlpha = VK_BLEND_FACTOR_SRC_ALPHA,\r
+ eOneMinusSrcAlpha = VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA,\r
+ eDstAlpha = VK_BLEND_FACTOR_DST_ALPHA,\r
+ eOneMinusDstAlpha = VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA,\r
+ eConstantColor = VK_BLEND_FACTOR_CONSTANT_COLOR,\r
+ eOneMinusConstantColor = VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COLOR,\r
+ eConstantAlpha = VK_BLEND_FACTOR_CONSTANT_ALPHA,\r
+ eOneMinusConstantAlpha = VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_ALPHA,\r
+ eSrcAlphaSaturate = VK_BLEND_FACTOR_SRC_ALPHA_SATURATE,\r
+ eSrc1Color = VK_BLEND_FACTOR_SRC1_COLOR,\r
+ eOneMinusSrc1Color = VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR,\r
+ eSrc1Alpha = VK_BLEND_FACTOR_SRC1_ALPHA,\r
+ eOneMinusSrc1Alpha = VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA\r
+ };\r
+\r
+ enum class BlendOp\r
+ {\r
+ eAdd = VK_BLEND_OP_ADD,\r
+ eSubtract = VK_BLEND_OP_SUBTRACT,\r
+ eReverseSubtract = VK_BLEND_OP_REVERSE_SUBTRACT,\r
+ eMin = VK_BLEND_OP_MIN,\r
+ eMax = VK_BLEND_OP_MAX,\r
+ eZeroEXT = VK_BLEND_OP_ZERO_EXT,\r
+ eSrcEXT = VK_BLEND_OP_SRC_EXT,\r
+ eDstEXT = VK_BLEND_OP_DST_EXT,\r
+ eSrcOverEXT = VK_BLEND_OP_SRC_OVER_EXT,\r
+ eDstOverEXT = VK_BLEND_OP_DST_OVER_EXT,\r
+ eSrcInEXT = VK_BLEND_OP_SRC_IN_EXT,\r
+ eDstInEXT = VK_BLEND_OP_DST_IN_EXT,\r
+ eSrcOutEXT = VK_BLEND_OP_SRC_OUT_EXT,\r
+ eDstOutEXT = VK_BLEND_OP_DST_OUT_EXT,\r
+ eSrcAtopEXT = VK_BLEND_OP_SRC_ATOP_EXT,\r
+ eDstAtopEXT = VK_BLEND_OP_DST_ATOP_EXT,\r
+ eXorEXT = VK_BLEND_OP_XOR_EXT,\r
+ eMultiplyEXT = VK_BLEND_OP_MULTIPLY_EXT,\r
+ eScreenEXT = VK_BLEND_OP_SCREEN_EXT,\r
+ eOverlayEXT = VK_BLEND_OP_OVERLAY_EXT,\r
+ eDarkenEXT = VK_BLEND_OP_DARKEN_EXT,\r
+ eLightenEXT = VK_BLEND_OP_LIGHTEN_EXT,\r
+ eColordodgeEXT = VK_BLEND_OP_COLORDODGE_EXT,\r
+ eColorburnEXT = VK_BLEND_OP_COLORBURN_EXT,\r
+ eHardlightEXT = VK_BLEND_OP_HARDLIGHT_EXT,\r
+ eSoftlightEXT = VK_BLEND_OP_SOFTLIGHT_EXT,\r
+ eDifferenceEXT = VK_BLEND_OP_DIFFERENCE_EXT,\r
+ eExclusionEXT = VK_BLEND_OP_EXCLUSION_EXT,\r
+ eInvertEXT = VK_BLEND_OP_INVERT_EXT,\r
+ eInvertRgbEXT = VK_BLEND_OP_INVERT_RGB_EXT,\r
+ eLineardodgeEXT = VK_BLEND_OP_LINEARDODGE_EXT,\r
+ eLinearburnEXT = VK_BLEND_OP_LINEARBURN_EXT,\r
+ eVividlightEXT = VK_BLEND_OP_VIVIDLIGHT_EXT,\r
+ eLinearlightEXT = VK_BLEND_OP_LINEARLIGHT_EXT,\r
+ ePinlightEXT = VK_BLEND_OP_PINLIGHT_EXT,\r
+ eHardmixEXT = VK_BLEND_OP_HARDMIX_EXT,\r
+ eHslHueEXT = VK_BLEND_OP_HSL_HUE_EXT,\r
+ eHslSaturationEXT = VK_BLEND_OP_HSL_SATURATION_EXT,\r
+ eHslColorEXT = VK_BLEND_OP_HSL_COLOR_EXT,\r
+ eHslLuminosityEXT = VK_BLEND_OP_HSL_LUMINOSITY_EXT,\r
+ ePlusEXT = VK_BLEND_OP_PLUS_EXT,\r
+ ePlusClampedEXT = VK_BLEND_OP_PLUS_CLAMPED_EXT,\r
+ ePlusClampedAlphaEXT = VK_BLEND_OP_PLUS_CLAMPED_ALPHA_EXT,\r
+ ePlusDarkerEXT = VK_BLEND_OP_PLUS_DARKER_EXT,\r
+ eMinusEXT = VK_BLEND_OP_MINUS_EXT,\r
+ eMinusClampedEXT = VK_BLEND_OP_MINUS_CLAMPED_EXT,\r
+ eContrastEXT = VK_BLEND_OP_CONTRAST_EXT,\r
+ eInvertOvgEXT = VK_BLEND_OP_INVERT_OVG_EXT,\r
+ eRedEXT = VK_BLEND_OP_RED_EXT,\r
+ eGreenEXT = VK_BLEND_OP_GREEN_EXT,\r
+ eBlueEXT = VK_BLEND_OP_BLUE_EXT\r
+ };\r
+\r
+ enum class StencilOp\r
+ {\r
+ eKeep = VK_STENCIL_OP_KEEP,\r
+ eZero = VK_STENCIL_OP_ZERO,\r
+ eReplace = VK_STENCIL_OP_REPLACE,\r
+ eIncrementAndClamp = VK_STENCIL_OP_INCREMENT_AND_CLAMP,\r
+ eDecrementAndClamp = VK_STENCIL_OP_DECREMENT_AND_CLAMP,\r
+ eInvert = VK_STENCIL_OP_INVERT,\r
+ eIncrementAndWrap = VK_STENCIL_OP_INCREMENT_AND_WRAP,\r
+ eDecrementAndWrap = VK_STENCIL_OP_DECREMENT_AND_WRAP\r
+ };\r
+\r
+ struct StencilOpState\r
+ {\r
+ StencilOpState( StencilOp failOp_ = StencilOp::eKeep, StencilOp passOp_ = StencilOp::eKeep, StencilOp depthFailOp_ = StencilOp::eKeep, CompareOp compareOp_ = CompareOp::eNever, uint32_t compareMask_ = 0, uint32_t writeMask_ = 0, uint32_t reference_ = 0 )\r
+ : failOp( failOp_ )\r
+ , passOp( passOp_ )\r
+ , depthFailOp( depthFailOp_ )\r
+ , compareOp( compareOp_ )\r
+ , compareMask( compareMask_ )\r
+ , writeMask( writeMask_ )\r
+ , reference( reference_ )\r
+ {\r
+ }\r
+\r
+ StencilOpState( VkStencilOpState const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( StencilOpState ) );\r
+ }\r
+\r
+ StencilOpState& operator=( VkStencilOpState const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( StencilOpState ) );\r
+ return *this;\r
+ }\r
+ StencilOpState& setFailOp( StencilOp failOp_ )\r
+ {\r
+ failOp = failOp_;\r
+ return *this;\r
+ }\r
+\r
+ StencilOpState& setPassOp( StencilOp passOp_ )\r
+ {\r
+ passOp = passOp_;\r
+ return *this;\r
+ }\r
+\r
+ StencilOpState& setDepthFailOp( StencilOp depthFailOp_ )\r
+ {\r
+ depthFailOp = depthFailOp_;\r
+ return *this;\r
+ }\r
+\r
+ StencilOpState& setCompareOp( CompareOp compareOp_ )\r
+ {\r
+ compareOp = compareOp_;\r
+ return *this;\r
+ }\r
+\r
+ StencilOpState& setCompareMask( uint32_t compareMask_ )\r
+ {\r
+ compareMask = compareMask_;\r
+ return *this;\r
+ }\r
+\r
+ StencilOpState& setWriteMask( uint32_t writeMask_ )\r
+ {\r
+ writeMask = writeMask_;\r
+ return *this;\r
+ }\r
+\r
+ StencilOpState& setReference( uint32_t reference_ )\r
+ {\r
+ reference = reference_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkStencilOpState&() const\r
+ {\r
+ return *reinterpret_cast<const VkStencilOpState*>(this);\r
+ }\r
+\r
+ bool operator==( StencilOpState const& rhs ) const\r
+ {\r
+ return ( failOp == rhs.failOp )\r
+ && ( passOp == rhs.passOp )\r
+ && ( depthFailOp == rhs.depthFailOp )\r
+ && ( compareOp == rhs.compareOp )\r
+ && ( compareMask == rhs.compareMask )\r
+ && ( writeMask == rhs.writeMask )\r
+ && ( reference == rhs.reference );\r
+ }\r
+\r
+ bool operator!=( StencilOpState const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ StencilOp failOp;\r
+ StencilOp passOp;\r
+ StencilOp depthFailOp;\r
+ CompareOp compareOp;\r
+ uint32_t compareMask;\r
+ uint32_t writeMask;\r
+ uint32_t reference;\r
+ };\r
+ static_assert( sizeof( StencilOpState ) == sizeof( VkStencilOpState ), "struct and wrapper have different size!" );\r
+\r
+ enum class LogicOp\r
+ {\r
+ eClear = VK_LOGIC_OP_CLEAR,\r
+ eAnd = VK_LOGIC_OP_AND,\r
+ eAndReverse = VK_LOGIC_OP_AND_REVERSE,\r
+ eCopy = VK_LOGIC_OP_COPY,\r
+ eAndInverted = VK_LOGIC_OP_AND_INVERTED,\r
+ eNoOp = VK_LOGIC_OP_NO_OP,\r
+ eXor = VK_LOGIC_OP_XOR,\r
+ eOr = VK_LOGIC_OP_OR,\r
+ eNor = VK_LOGIC_OP_NOR,\r
+ eEquivalent = VK_LOGIC_OP_EQUIVALENT,\r
+ eInvert = VK_LOGIC_OP_INVERT,\r
+ eOrReverse = VK_LOGIC_OP_OR_REVERSE,\r
+ eCopyInverted = VK_LOGIC_OP_COPY_INVERTED,\r
+ eOrInverted = VK_LOGIC_OP_OR_INVERTED,\r
+ eNand = VK_LOGIC_OP_NAND,\r
+ eSet = VK_LOGIC_OP_SET\r
+ };\r
+\r
+ enum class InternalAllocationType\r
+ {\r
+ eExecutable = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE\r
+ };\r
+\r
+ enum class SystemAllocationScope\r
+ {\r
+ eCommand = VK_SYSTEM_ALLOCATION_SCOPE_COMMAND,\r
+ eObject = VK_SYSTEM_ALLOCATION_SCOPE_OBJECT,\r
+ eCache = VK_SYSTEM_ALLOCATION_SCOPE_CACHE,\r
+ eDevice = VK_SYSTEM_ALLOCATION_SCOPE_DEVICE,\r
+ eInstance = VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE\r
+ };\r
+\r
+ enum class PhysicalDeviceType\r
+ {\r
+ eOther = VK_PHYSICAL_DEVICE_TYPE_OTHER,\r
+ eIntegratedGpu = VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU,\r
+ eDiscreteGpu = VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU,\r
+ eVirtualGpu = VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU,\r
+ eCpu = VK_PHYSICAL_DEVICE_TYPE_CPU\r
+ };\r
+\r
+ enum class VertexInputRate\r
+ {\r
+ eVertex = VK_VERTEX_INPUT_RATE_VERTEX,\r
+ eInstance = VK_VERTEX_INPUT_RATE_INSTANCE\r
+ };\r
+\r
+ struct VertexInputBindingDescription\r
+ {\r
+ VertexInputBindingDescription( uint32_t binding_ = 0, uint32_t stride_ = 0, VertexInputRate inputRate_ = VertexInputRate::eVertex )\r
+ : binding( binding_ )\r
+ , stride( stride_ )\r
+ , inputRate( inputRate_ )\r
+ {\r
+ }\r
+\r
+ VertexInputBindingDescription( VkVertexInputBindingDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( VertexInputBindingDescription ) );\r
+ }\r
+\r
+ VertexInputBindingDescription& operator=( VkVertexInputBindingDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( VertexInputBindingDescription ) );\r
+ return *this;\r
+ }\r
+ VertexInputBindingDescription& setBinding( uint32_t binding_ )\r
+ {\r
+ binding = binding_;\r
+ return *this;\r
+ }\r
+\r
+ VertexInputBindingDescription& setStride( uint32_t stride_ )\r
+ {\r
+ stride = stride_;\r
+ return *this;\r
+ }\r
+\r
+ VertexInputBindingDescription& setInputRate( VertexInputRate inputRate_ )\r
+ {\r
+ inputRate = inputRate_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkVertexInputBindingDescription&() const\r
+ {\r
+ return *reinterpret_cast<const VkVertexInputBindingDescription*>(this);\r
+ }\r
+\r
+ bool operator==( VertexInputBindingDescription const& rhs ) const\r
+ {\r
+ return ( binding == rhs.binding )\r
+ && ( stride == rhs.stride )\r
+ && ( inputRate == rhs.inputRate );\r
+ }\r
+\r
+ bool operator!=( VertexInputBindingDescription const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t binding;\r
+ uint32_t stride;\r
+ VertexInputRate inputRate;\r
+ };\r
+ static_assert( sizeof( VertexInputBindingDescription ) == sizeof( VkVertexInputBindingDescription ), "struct and wrapper have different size!" );\r
+\r
+ enum class Format\r
+ {\r
+ eUndefined = VK_FORMAT_UNDEFINED,\r
+ eR4G4UnormPack8 = VK_FORMAT_R4G4_UNORM_PACK8,\r
+ eR4G4B4A4UnormPack16 = VK_FORMAT_R4G4B4A4_UNORM_PACK16,\r
+ eB4G4R4A4UnormPack16 = VK_FORMAT_B4G4R4A4_UNORM_PACK16,\r
+ eR5G6B5UnormPack16 = VK_FORMAT_R5G6B5_UNORM_PACK16,\r
+ eB5G6R5UnormPack16 = VK_FORMAT_B5G6R5_UNORM_PACK16,\r
+ eR5G5B5A1UnormPack16 = VK_FORMAT_R5G5B5A1_UNORM_PACK16,\r
+ eB5G5R5A1UnormPack16 = VK_FORMAT_B5G5R5A1_UNORM_PACK16,\r
+ eA1R5G5B5UnormPack16 = VK_FORMAT_A1R5G5B5_UNORM_PACK16,\r
+ eR8Unorm = VK_FORMAT_R8_UNORM,\r
+ eR8Snorm = VK_FORMAT_R8_SNORM,\r
+ eR8Uscaled = VK_FORMAT_R8_USCALED,\r
+ eR8Sscaled = VK_FORMAT_R8_SSCALED,\r
+ eR8Uint = VK_FORMAT_R8_UINT,\r
+ eR8Sint = VK_FORMAT_R8_SINT,\r
+ eR8Srgb = VK_FORMAT_R8_SRGB,\r
+ eR8G8Unorm = VK_FORMAT_R8G8_UNORM,\r
+ eR8G8Snorm = VK_FORMAT_R8G8_SNORM,\r
+ eR8G8Uscaled = VK_FORMAT_R8G8_USCALED,\r
+ eR8G8Sscaled = VK_FORMAT_R8G8_SSCALED,\r
+ eR8G8Uint = VK_FORMAT_R8G8_UINT,\r
+ eR8G8Sint = VK_FORMAT_R8G8_SINT,\r
+ eR8G8Srgb = VK_FORMAT_R8G8_SRGB,\r
+ eR8G8B8Unorm = VK_FORMAT_R8G8B8_UNORM,\r
+ eR8G8B8Snorm = VK_FORMAT_R8G8B8_SNORM,\r
+ eR8G8B8Uscaled = VK_FORMAT_R8G8B8_USCALED,\r
+ eR8G8B8Sscaled = VK_FORMAT_R8G8B8_SSCALED,\r
+ eR8G8B8Uint = VK_FORMAT_R8G8B8_UINT,\r
+ eR8G8B8Sint = VK_FORMAT_R8G8B8_SINT,\r
+ eR8G8B8Srgb = VK_FORMAT_R8G8B8_SRGB,\r
+ eB8G8R8Unorm = VK_FORMAT_B8G8R8_UNORM,\r
+ eB8G8R8Snorm = VK_FORMAT_B8G8R8_SNORM,\r
+ eB8G8R8Uscaled = VK_FORMAT_B8G8R8_USCALED,\r
+ eB8G8R8Sscaled = VK_FORMAT_B8G8R8_SSCALED,\r
+ eB8G8R8Uint = VK_FORMAT_B8G8R8_UINT,\r
+ eB8G8R8Sint = VK_FORMAT_B8G8R8_SINT,\r
+ eB8G8R8Srgb = VK_FORMAT_B8G8R8_SRGB,\r
+ eR8G8B8A8Unorm = VK_FORMAT_R8G8B8A8_UNORM,\r
+ eR8G8B8A8Snorm = VK_FORMAT_R8G8B8A8_SNORM,\r
+ eR8G8B8A8Uscaled = VK_FORMAT_R8G8B8A8_USCALED,\r
+ eR8G8B8A8Sscaled = VK_FORMAT_R8G8B8A8_SSCALED,\r
+ eR8G8B8A8Uint = VK_FORMAT_R8G8B8A8_UINT,\r
+ eR8G8B8A8Sint = VK_FORMAT_R8G8B8A8_SINT,\r
+ eR8G8B8A8Srgb = VK_FORMAT_R8G8B8A8_SRGB,\r
+ eB8G8R8A8Unorm = VK_FORMAT_B8G8R8A8_UNORM,\r
+ eB8G8R8A8Snorm = VK_FORMAT_B8G8R8A8_SNORM,\r
+ eB8G8R8A8Uscaled = VK_FORMAT_B8G8R8A8_USCALED,\r
+ eB8G8R8A8Sscaled = VK_FORMAT_B8G8R8A8_SSCALED,\r
+ eB8G8R8A8Uint = VK_FORMAT_B8G8R8A8_UINT,\r
+ eB8G8R8A8Sint = VK_FORMAT_B8G8R8A8_SINT,\r
+ eB8G8R8A8Srgb = VK_FORMAT_B8G8R8A8_SRGB,\r
+ eA8B8G8R8UnormPack32 = VK_FORMAT_A8B8G8R8_UNORM_PACK32,\r
+ eA8B8G8R8SnormPack32 = VK_FORMAT_A8B8G8R8_SNORM_PACK32,\r
+ eA8B8G8R8UscaledPack32 = VK_FORMAT_A8B8G8R8_USCALED_PACK32,\r
+ eA8B8G8R8SscaledPack32 = VK_FORMAT_A8B8G8R8_SSCALED_PACK32,\r
+ eA8B8G8R8UintPack32 = VK_FORMAT_A8B8G8R8_UINT_PACK32,\r
+ eA8B8G8R8SintPack32 = VK_FORMAT_A8B8G8R8_SINT_PACK32,\r
+ eA8B8G8R8SrgbPack32 = VK_FORMAT_A8B8G8R8_SRGB_PACK32,\r
+ eA2R10G10B10UnormPack32 = VK_FORMAT_A2R10G10B10_UNORM_PACK32,\r
+ eA2R10G10B10SnormPack32 = VK_FORMAT_A2R10G10B10_SNORM_PACK32,\r
+ eA2R10G10B10UscaledPack32 = VK_FORMAT_A2R10G10B10_USCALED_PACK32,\r
+ eA2R10G10B10SscaledPack32 = VK_FORMAT_A2R10G10B10_SSCALED_PACK32,\r
+ eA2R10G10B10UintPack32 = VK_FORMAT_A2R10G10B10_UINT_PACK32,\r
+ eA2R10G10B10SintPack32 = VK_FORMAT_A2R10G10B10_SINT_PACK32,\r
+ eA2B10G10R10UnormPack32 = VK_FORMAT_A2B10G10R10_UNORM_PACK32,\r
+ eA2B10G10R10SnormPack32 = VK_FORMAT_A2B10G10R10_SNORM_PACK32,\r
+ eA2B10G10R10UscaledPack32 = VK_FORMAT_A2B10G10R10_USCALED_PACK32,\r
+ eA2B10G10R10SscaledPack32 = VK_FORMAT_A2B10G10R10_SSCALED_PACK32,\r
+ eA2B10G10R10UintPack32 = VK_FORMAT_A2B10G10R10_UINT_PACK32,\r
+ eA2B10G10R10SintPack32 = VK_FORMAT_A2B10G10R10_SINT_PACK32,\r
+ eR16Unorm = VK_FORMAT_R16_UNORM,\r
+ eR16Snorm = VK_FORMAT_R16_SNORM,\r
+ eR16Uscaled = VK_FORMAT_R16_USCALED,\r
+ eR16Sscaled = VK_FORMAT_R16_SSCALED,\r
+ eR16Uint = VK_FORMAT_R16_UINT,\r
+ eR16Sint = VK_FORMAT_R16_SINT,\r
+ eR16Sfloat = VK_FORMAT_R16_SFLOAT,\r
+ eR16G16Unorm = VK_FORMAT_R16G16_UNORM,\r
+ eR16G16Snorm = VK_FORMAT_R16G16_SNORM,\r
+ eR16G16Uscaled = VK_FORMAT_R16G16_USCALED,\r
+ eR16G16Sscaled = VK_FORMAT_R16G16_SSCALED,\r
+ eR16G16Uint = VK_FORMAT_R16G16_UINT,\r
+ eR16G16Sint = VK_FORMAT_R16G16_SINT,\r
+ eR16G16Sfloat = VK_FORMAT_R16G16_SFLOAT,\r
+ eR16G16B16Unorm = VK_FORMAT_R16G16B16_UNORM,\r
+ eR16G16B16Snorm = VK_FORMAT_R16G16B16_SNORM,\r
+ eR16G16B16Uscaled = VK_FORMAT_R16G16B16_USCALED,\r
+ eR16G16B16Sscaled = VK_FORMAT_R16G16B16_SSCALED,\r
+ eR16G16B16Uint = VK_FORMAT_R16G16B16_UINT,\r
+ eR16G16B16Sint = VK_FORMAT_R16G16B16_SINT,\r
+ eR16G16B16Sfloat = VK_FORMAT_R16G16B16_SFLOAT,\r
+ eR16G16B16A16Unorm = VK_FORMAT_R16G16B16A16_UNORM,\r
+ eR16G16B16A16Snorm = VK_FORMAT_R16G16B16A16_SNORM,\r
+ eR16G16B16A16Uscaled = VK_FORMAT_R16G16B16A16_USCALED,\r
+ eR16G16B16A16Sscaled = VK_FORMAT_R16G16B16A16_SSCALED,\r
+ eR16G16B16A16Uint = VK_FORMAT_R16G16B16A16_UINT,\r
+ eR16G16B16A16Sint = VK_FORMAT_R16G16B16A16_SINT,\r
+ eR16G16B16A16Sfloat = VK_FORMAT_R16G16B16A16_SFLOAT,\r
+ eR32Uint = VK_FORMAT_R32_UINT,\r
+ eR32Sint = VK_FORMAT_R32_SINT,\r
+ eR32Sfloat = VK_FORMAT_R32_SFLOAT,\r
+ eR32G32Uint = VK_FORMAT_R32G32_UINT,\r
+ eR32G32Sint = VK_FORMAT_R32G32_SINT,\r
+ eR32G32Sfloat = VK_FORMAT_R32G32_SFLOAT,\r
+ eR32G32B32Uint = VK_FORMAT_R32G32B32_UINT,\r
+ eR32G32B32Sint = VK_FORMAT_R32G32B32_SINT,\r
+ eR32G32B32Sfloat = VK_FORMAT_R32G32B32_SFLOAT,\r
+ eR32G32B32A32Uint = VK_FORMAT_R32G32B32A32_UINT,\r
+ eR32G32B32A32Sint = VK_FORMAT_R32G32B32A32_SINT,\r
+ eR32G32B32A32Sfloat = VK_FORMAT_R32G32B32A32_SFLOAT,\r
+ eR64Uint = VK_FORMAT_R64_UINT,\r
+ eR64Sint = VK_FORMAT_R64_SINT,\r
+ eR64Sfloat = VK_FORMAT_R64_SFLOAT,\r
+ eR64G64Uint = VK_FORMAT_R64G64_UINT,\r
+ eR64G64Sint = VK_FORMAT_R64G64_SINT,\r
+ eR64G64Sfloat = VK_FORMAT_R64G64_SFLOAT,\r
+ eR64G64B64Uint = VK_FORMAT_R64G64B64_UINT,\r
+ eR64G64B64Sint = VK_FORMAT_R64G64B64_SINT,\r
+ eR64G64B64Sfloat = VK_FORMAT_R64G64B64_SFLOAT,\r
+ eR64G64B64A64Uint = VK_FORMAT_R64G64B64A64_UINT,\r
+ eR64G64B64A64Sint = VK_FORMAT_R64G64B64A64_SINT,\r
+ eR64G64B64A64Sfloat = VK_FORMAT_R64G64B64A64_SFLOAT,\r
+ eB10G11R11UfloatPack32 = VK_FORMAT_B10G11R11_UFLOAT_PACK32,\r
+ eE5B9G9R9UfloatPack32 = VK_FORMAT_E5B9G9R9_UFLOAT_PACK32,\r
+ eD16Unorm = VK_FORMAT_D16_UNORM,\r
+ eX8D24UnormPack32 = VK_FORMAT_X8_D24_UNORM_PACK32,\r
+ eD32Sfloat = VK_FORMAT_D32_SFLOAT,\r
+ eS8Uint = VK_FORMAT_S8_UINT,\r
+ eD16UnormS8Uint = VK_FORMAT_D16_UNORM_S8_UINT,\r
+ eD24UnormS8Uint = VK_FORMAT_D24_UNORM_S8_UINT,\r
+ eD32SfloatS8Uint = VK_FORMAT_D32_SFLOAT_S8_UINT,\r
+ eBc1RgbUnormBlock = VK_FORMAT_BC1_RGB_UNORM_BLOCK,\r
+ eBc1RgbSrgbBlock = VK_FORMAT_BC1_RGB_SRGB_BLOCK,\r
+ eBc1RgbaUnormBlock = VK_FORMAT_BC1_RGBA_UNORM_BLOCK,\r
+ eBc1RgbaSrgbBlock = VK_FORMAT_BC1_RGBA_SRGB_BLOCK,\r
+ eBc2UnormBlock = VK_FORMAT_BC2_UNORM_BLOCK,\r
+ eBc2SrgbBlock = VK_FORMAT_BC2_SRGB_BLOCK,\r
+ eBc3UnormBlock = VK_FORMAT_BC3_UNORM_BLOCK,\r
+ eBc3SrgbBlock = VK_FORMAT_BC3_SRGB_BLOCK,\r
+ eBc4UnormBlock = VK_FORMAT_BC4_UNORM_BLOCK,\r
+ eBc4SnormBlock = VK_FORMAT_BC4_SNORM_BLOCK,\r
+ eBc5UnormBlock = VK_FORMAT_BC5_UNORM_BLOCK,\r
+ eBc5SnormBlock = VK_FORMAT_BC5_SNORM_BLOCK,\r
+ eBc6HUfloatBlock = VK_FORMAT_BC6H_UFLOAT_BLOCK,\r
+ eBc6HSfloatBlock = VK_FORMAT_BC6H_SFLOAT_BLOCK,\r
+ eBc7UnormBlock = VK_FORMAT_BC7_UNORM_BLOCK,\r
+ eBc7SrgbBlock = VK_FORMAT_BC7_SRGB_BLOCK,\r
+ eEtc2R8G8B8UnormBlock = VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK,\r
+ eEtc2R8G8B8SrgbBlock = VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK,\r
+ eEtc2R8G8B8A1UnormBlock = VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK,\r
+ eEtc2R8G8B8A1SrgbBlock = VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK,\r
+ eEtc2R8G8B8A8UnormBlock = VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK,\r
+ eEtc2R8G8B8A8SrgbBlock = VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK,\r
+ eEacR11UnormBlock = VK_FORMAT_EAC_R11_UNORM_BLOCK,\r
+ eEacR11SnormBlock = VK_FORMAT_EAC_R11_SNORM_BLOCK,\r
+ eEacR11G11UnormBlock = VK_FORMAT_EAC_R11G11_UNORM_BLOCK,\r
+ eEacR11G11SnormBlock = VK_FORMAT_EAC_R11G11_SNORM_BLOCK,\r
+ eAstc4x4UnormBlock = VK_FORMAT_ASTC_4x4_UNORM_BLOCK,\r
+ eAstc4x4SrgbBlock = VK_FORMAT_ASTC_4x4_SRGB_BLOCK,\r
+ eAstc5x4UnormBlock = VK_FORMAT_ASTC_5x4_UNORM_BLOCK,\r
+ eAstc5x4SrgbBlock = VK_FORMAT_ASTC_5x4_SRGB_BLOCK,\r
+ eAstc5x5UnormBlock = VK_FORMAT_ASTC_5x5_UNORM_BLOCK,\r
+ eAstc5x5SrgbBlock = VK_FORMAT_ASTC_5x5_SRGB_BLOCK,\r
+ eAstc6x5UnormBlock = VK_FORMAT_ASTC_6x5_UNORM_BLOCK,\r
+ eAstc6x5SrgbBlock = VK_FORMAT_ASTC_6x5_SRGB_BLOCK,\r
+ eAstc6x6UnormBlock = VK_FORMAT_ASTC_6x6_UNORM_BLOCK,\r
+ eAstc6x6SrgbBlock = VK_FORMAT_ASTC_6x6_SRGB_BLOCK,\r
+ eAstc8x5UnormBlock = VK_FORMAT_ASTC_8x5_UNORM_BLOCK,\r
+ eAstc8x5SrgbBlock = VK_FORMAT_ASTC_8x5_SRGB_BLOCK,\r
+ eAstc8x6UnormBlock = VK_FORMAT_ASTC_8x6_UNORM_BLOCK,\r
+ eAstc8x6SrgbBlock = VK_FORMAT_ASTC_8x6_SRGB_BLOCK,\r
+ eAstc8x8UnormBlock = VK_FORMAT_ASTC_8x8_UNORM_BLOCK,\r
+ eAstc8x8SrgbBlock = VK_FORMAT_ASTC_8x8_SRGB_BLOCK,\r
+ eAstc10x5UnormBlock = VK_FORMAT_ASTC_10x5_UNORM_BLOCK,\r
+ eAstc10x5SrgbBlock = VK_FORMAT_ASTC_10x5_SRGB_BLOCK,\r
+ eAstc10x6UnormBlock = VK_FORMAT_ASTC_10x6_UNORM_BLOCK,\r
+ eAstc10x6SrgbBlock = VK_FORMAT_ASTC_10x6_SRGB_BLOCK,\r
+ eAstc10x8UnormBlock = VK_FORMAT_ASTC_10x8_UNORM_BLOCK,\r
+ eAstc10x8SrgbBlock = VK_FORMAT_ASTC_10x8_SRGB_BLOCK,\r
+ eAstc10x10UnormBlock = VK_FORMAT_ASTC_10x10_UNORM_BLOCK,\r
+ eAstc10x10SrgbBlock = VK_FORMAT_ASTC_10x10_SRGB_BLOCK,\r
+ eAstc12x10UnormBlock = VK_FORMAT_ASTC_12x10_UNORM_BLOCK,\r
+ eAstc12x10SrgbBlock = VK_FORMAT_ASTC_12x10_SRGB_BLOCK,\r
+ eAstc12x12UnormBlock = VK_FORMAT_ASTC_12x12_UNORM_BLOCK,\r
+ eAstc12x12SrgbBlock = VK_FORMAT_ASTC_12x12_SRGB_BLOCK,\r
+ eG8B8G8R8422Unorm = VK_FORMAT_G8B8G8R8_422_UNORM,\r
+ eG8B8G8R8422UnormKHR = VK_FORMAT_G8B8G8R8_422_UNORM,\r
+ eB8G8R8G8422Unorm = VK_FORMAT_B8G8R8G8_422_UNORM,\r
+ eB8G8R8G8422UnormKHR = VK_FORMAT_B8G8R8G8_422_UNORM,\r
+ eG8B8R83Plane420Unorm = VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM,\r
+ eG8B8R83Plane420UnormKHR = VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM,\r
+ eG8B8R82Plane420Unorm = VK_FORMAT_G8_B8R8_2PLANE_420_UNORM,\r
+ eG8B8R82Plane420UnormKHR = VK_FORMAT_G8_B8R8_2PLANE_420_UNORM,\r
+ eG8B8R83Plane422Unorm = VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM,\r
+ eG8B8R83Plane422UnormKHR = VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM,\r
+ eG8B8R82Plane422Unorm = VK_FORMAT_G8_B8R8_2PLANE_422_UNORM,\r
+ eG8B8R82Plane422UnormKHR = VK_FORMAT_G8_B8R8_2PLANE_422_UNORM,\r
+ eG8B8R83Plane444Unorm = VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM,\r
+ eG8B8R83Plane444UnormKHR = VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM,\r
+ eR10X6UnormPack16 = VK_FORMAT_R10X6_UNORM_PACK16,\r
+ eR10X6UnormPack16KHR = VK_FORMAT_R10X6_UNORM_PACK16,\r
+ eR10X6G10X6Unorm2Pack16 = VK_FORMAT_R10X6G10X6_UNORM_2PACK16,\r
+ eR10X6G10X6Unorm2Pack16KHR = VK_FORMAT_R10X6G10X6_UNORM_2PACK16,\r
+ eR10X6G10X6B10X6A10X6Unorm4Pack16 = VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16,\r
+ eR10X6G10X6B10X6A10X6Unorm4Pack16KHR = VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16,\r
+ eG10X6B10X6G10X6R10X6422Unorm4Pack16 = VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16,\r
+ eG10X6B10X6G10X6R10X6422Unorm4Pack16KHR = VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16,\r
+ eB10X6G10X6R10X6G10X6422Unorm4Pack16 = VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16,\r
+ eB10X6G10X6R10X6G10X6422Unorm4Pack16KHR = VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16,\r
+ eG10X6B10X6R10X63Plane420Unorm3Pack16 = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16,\r
+ eG10X6B10X6R10X63Plane420Unorm3Pack16KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16,\r
+ eG10X6B10X6R10X62Plane420Unorm3Pack16 = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16,\r
+ eG10X6B10X6R10X62Plane420Unorm3Pack16KHR = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16,\r
+ eG10X6B10X6R10X63Plane422Unorm3Pack16 = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16,\r
+ eG10X6B10X6R10X63Plane422Unorm3Pack16KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16,\r
+ eG10X6B10X6R10X62Plane422Unorm3Pack16 = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16,\r
+ eG10X6B10X6R10X62Plane422Unorm3Pack16KHR = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16,\r
+ eG10X6B10X6R10X63Plane444Unorm3Pack16 = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16,\r
+ eG10X6B10X6R10X63Plane444Unorm3Pack16KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16,\r
+ eR12X4UnormPack16 = VK_FORMAT_R12X4_UNORM_PACK16,\r
+ eR12X4UnormPack16KHR = VK_FORMAT_R12X4_UNORM_PACK16,\r
+ eR12X4G12X4Unorm2Pack16 = VK_FORMAT_R12X4G12X4_UNORM_2PACK16,\r
+ eR12X4G12X4Unorm2Pack16KHR = VK_FORMAT_R12X4G12X4_UNORM_2PACK16,\r
+ eR12X4G12X4B12X4A12X4Unorm4Pack16 = VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16,\r
+ eR12X4G12X4B12X4A12X4Unorm4Pack16KHR = VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16,\r
+ eG12X4B12X4G12X4R12X4422Unorm4Pack16 = VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16,\r
+ eG12X4B12X4G12X4R12X4422Unorm4Pack16KHR = VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16,\r
+ eB12X4G12X4R12X4G12X4422Unorm4Pack16 = VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16,\r
+ eB12X4G12X4R12X4G12X4422Unorm4Pack16KHR = VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16,\r
+ eG12X4B12X4R12X43Plane420Unorm3Pack16 = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16,\r
+ eG12X4B12X4R12X43Plane420Unorm3Pack16KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16,\r
+ eG12X4B12X4R12X42Plane420Unorm3Pack16 = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16,\r
+ eG12X4B12X4R12X42Plane420Unorm3Pack16KHR = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16,\r
+ eG12X4B12X4R12X43Plane422Unorm3Pack16 = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16,\r
+ eG12X4B12X4R12X43Plane422Unorm3Pack16KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16,\r
+ eG12X4B12X4R12X42Plane422Unorm3Pack16 = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16,\r
+ eG12X4B12X4R12X42Plane422Unorm3Pack16KHR = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16,\r
+ eG12X4B12X4R12X43Plane444Unorm3Pack16 = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16,\r
+ eG12X4B12X4R12X43Plane444Unorm3Pack16KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16,\r
+ eG16B16G16R16422Unorm = VK_FORMAT_G16B16G16R16_422_UNORM,\r
+ eG16B16G16R16422UnormKHR = VK_FORMAT_G16B16G16R16_422_UNORM,\r
+ eB16G16R16G16422Unorm = VK_FORMAT_B16G16R16G16_422_UNORM,\r
+ eB16G16R16G16422UnormKHR = VK_FORMAT_B16G16R16G16_422_UNORM,\r
+ eG16B16R163Plane420Unorm = VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM,\r
+ eG16B16R163Plane420UnormKHR = VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM,\r
+ eG16B16R162Plane420Unorm = VK_FORMAT_G16_B16R16_2PLANE_420_UNORM,\r
+ eG16B16R162Plane420UnormKHR = VK_FORMAT_G16_B16R16_2PLANE_420_UNORM,\r
+ eG16B16R163Plane422Unorm = VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM,\r
+ eG16B16R163Plane422UnormKHR = VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM,\r
+ eG16B16R162Plane422Unorm = VK_FORMAT_G16_B16R16_2PLANE_422_UNORM,\r
+ eG16B16R162Plane422UnormKHR = VK_FORMAT_G16_B16R16_2PLANE_422_UNORM,\r
+ eG16B16R163Plane444Unorm = VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM,\r
+ eG16B16R163Plane444UnormKHR = VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM,\r
+ ePvrtc12BppUnormBlockIMG = VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG,\r
+ ePvrtc14BppUnormBlockIMG = VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG,\r
+ ePvrtc22BppUnormBlockIMG = VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG,\r
+ ePvrtc24BppUnormBlockIMG = VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG,\r
+ ePvrtc12BppSrgbBlockIMG = VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG,\r
+ ePvrtc14BppSrgbBlockIMG = VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG,\r
+ ePvrtc22BppSrgbBlockIMG = VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG,\r
+ ePvrtc24BppSrgbBlockIMG = VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG\r
+ };\r
+\r
+ struct VertexInputAttributeDescription\r
+ {\r
+ VertexInputAttributeDescription( uint32_t location_ = 0, uint32_t binding_ = 0, Format format_ = Format::eUndefined, uint32_t offset_ = 0 )\r
+ : location( location_ )\r
+ , binding( binding_ )\r
+ , format( format_ )\r
+ , offset( offset_ )\r
+ {\r
+ }\r
+\r
+ VertexInputAttributeDescription( VkVertexInputAttributeDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( VertexInputAttributeDescription ) );\r
+ }\r
+\r
+ VertexInputAttributeDescription& operator=( VkVertexInputAttributeDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( VertexInputAttributeDescription ) );\r
+ return *this;\r
+ }\r
+ VertexInputAttributeDescription& setLocation( uint32_t location_ )\r
+ {\r
+ location = location_;\r
+ return *this;\r
+ }\r
+\r
+ VertexInputAttributeDescription& setBinding( uint32_t binding_ )\r
+ {\r
+ binding = binding_;\r
+ return *this;\r
+ }\r
+\r
+ VertexInputAttributeDescription& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ VertexInputAttributeDescription& setOffset( uint32_t offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkVertexInputAttributeDescription&() const\r
+ {\r
+ return *reinterpret_cast<const VkVertexInputAttributeDescription*>(this);\r
+ }\r
+\r
+ bool operator==( VertexInputAttributeDescription const& rhs ) const\r
+ {\r
+ return ( location == rhs.location )\r
+ && ( binding == rhs.binding )\r
+ && ( format == rhs.format )\r
+ && ( offset == rhs.offset );\r
+ }\r
+\r
+ bool operator!=( VertexInputAttributeDescription const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t location;\r
+ uint32_t binding;\r
+ Format format;\r
+ uint32_t offset;\r
+ };\r
+ static_assert( sizeof( VertexInputAttributeDescription ) == sizeof( VkVertexInputAttributeDescription ), "struct and wrapper have different size!" );\r
+\r
+ enum class StructureType\r
+ {\r
+ eApplicationInfo = VK_STRUCTURE_TYPE_APPLICATION_INFO,\r
+ eInstanceCreateInfo = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO,\r
+ eDeviceQueueCreateInfo = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO,\r
+ eDeviceCreateInfo = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,\r
+ eSubmitInfo = VK_STRUCTURE_TYPE_SUBMIT_INFO,\r
+ eMemoryAllocateInfo = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO,\r
+ eMappedMemoryRange = VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE,\r
+ eBindSparseInfo = VK_STRUCTURE_TYPE_BIND_SPARSE_INFO,\r
+ eFenceCreateInfo = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO,\r
+ eSemaphoreCreateInfo = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO,\r
+ eEventCreateInfo = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO,\r
+ eQueryPoolCreateInfo = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO,\r
+ eBufferCreateInfo = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO,\r
+ eBufferViewCreateInfo = VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO,\r
+ eImageCreateInfo = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO,\r
+ eImageViewCreateInfo = VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO,\r
+ eShaderModuleCreateInfo = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO,\r
+ ePipelineCacheCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO,\r
+ ePipelineShaderStageCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO,\r
+ ePipelineVertexInputStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO,\r
+ ePipelineInputAssemblyStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO,\r
+ ePipelineTessellationStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO,\r
+ ePipelineViewportStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO,\r
+ ePipelineRasterizationStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO,\r
+ ePipelineMultisampleStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO,\r
+ ePipelineDepthStencilStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO,\r
+ ePipelineColorBlendStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO,\r
+ ePipelineDynamicStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO,\r
+ eGraphicsPipelineCreateInfo = VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO,\r
+ eComputePipelineCreateInfo = VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO,\r
+ ePipelineLayoutCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO,\r
+ eSamplerCreateInfo = VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO,\r
+ eDescriptorSetLayoutCreateInfo = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO,\r
+ eDescriptorPoolCreateInfo = VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO,\r
+ eDescriptorSetAllocateInfo = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO,\r
+ eWriteDescriptorSet = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET,\r
+ eCopyDescriptorSet = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET,\r
+ eFramebufferCreateInfo = VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO,\r
+ eRenderPassCreateInfo = VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO,\r
+ eCommandPoolCreateInfo = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO,\r
+ eCommandBufferAllocateInfo = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO,\r
+ eCommandBufferInheritanceInfo = VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO,\r
+ eCommandBufferBeginInfo = VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO,\r
+ eRenderPassBeginInfo = VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO,\r
+ eBufferMemoryBarrier = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER,\r
+ eImageMemoryBarrier = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER,\r
+ eMemoryBarrier = VK_STRUCTURE_TYPE_MEMORY_BARRIER,\r
+ eLoaderInstanceCreateInfo = VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO,\r
+ eLoaderDeviceCreateInfo = VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO,\r
+ ePhysicalDeviceSubgroupProperties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES,\r
+ eBindBufferMemoryInfo = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO,\r
+ eBindBufferMemoryInfoKHR = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO,\r
+ eBindImageMemoryInfo = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO,\r
+ eBindImageMemoryInfoKHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO,\r
+ ePhysicalDevice16BitStorageFeatures = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES,\r
+ ePhysicalDevice16BitStorageFeaturesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES,\r
+ eMemoryDedicatedRequirements = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS,\r
+ eMemoryDedicatedRequirementsKHR = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS,\r
+ eMemoryDedicatedAllocateInfo = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO,\r
+ eMemoryDedicatedAllocateInfoKHR = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO,\r
+ eMemoryAllocateFlagsInfo = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO,\r
+ eMemoryAllocateFlagsInfoKHR = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO,\r
+ eDeviceGroupRenderPassBeginInfo = VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO,\r
+ eDeviceGroupRenderPassBeginInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO,\r
+ eDeviceGroupCommandBufferBeginInfo = VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO,\r
+ eDeviceGroupCommandBufferBeginInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO,\r
+ eDeviceGroupSubmitInfo = VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO,\r
+ eDeviceGroupSubmitInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO,\r
+ eDeviceGroupBindSparseInfo = VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO,\r
+ eDeviceGroupBindSparseInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO,\r
+ eBindBufferMemoryDeviceGroupInfo = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO,\r
+ eBindBufferMemoryDeviceGroupInfoKHR = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO,\r
+ eBindImageMemoryDeviceGroupInfo = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO,\r
+ eBindImageMemoryDeviceGroupInfoKHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO,\r
+ ePhysicalDeviceGroupProperties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES,\r
+ ePhysicalDeviceGroupPropertiesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES,\r
+ eDeviceGroupDeviceCreateInfo = VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO,\r
+ eDeviceGroupDeviceCreateInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO,\r
+ eBufferMemoryRequirementsInfo2 = VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2,\r
+ eBufferMemoryRequirementsInfo2KHR = VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2,\r
+ eImageMemoryRequirementsInfo2 = VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2,\r
+ eImageMemoryRequirementsInfo2KHR = VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2,\r
+ eImageSparseMemoryRequirementsInfo2 = VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2,\r
+ eImageSparseMemoryRequirementsInfo2KHR = VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2,\r
+ eMemoryRequirements2 = VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2,\r
+ eMemoryRequirements2KHR = VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2,\r
+ eSparseImageMemoryRequirements2 = VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2,\r
+ eSparseImageMemoryRequirements2KHR = VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2,\r
+ ePhysicalDeviceFeatures2 = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2,\r
+ ePhysicalDeviceFeatures2KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2,\r
+ ePhysicalDeviceProperties2 = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2,\r
+ ePhysicalDeviceProperties2KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2,\r
+ eFormatProperties2 = VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2,\r
+ eFormatProperties2KHR = VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2,\r
+ eImageFormatProperties2 = VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2,\r
+ eImageFormatProperties2KHR = VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2,\r
+ ePhysicalDeviceImageFormatInfo2 = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2,\r
+ ePhysicalDeviceImageFormatInfo2KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2,\r
+ eQueueFamilyProperties2 = VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2,\r
+ eQueueFamilyProperties2KHR = VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2,\r
+ ePhysicalDeviceMemoryProperties2 = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2,\r
+ ePhysicalDeviceMemoryProperties2KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2,\r
+ eSparseImageFormatProperties2 = VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2,\r
+ eSparseImageFormatProperties2KHR = VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2,\r
+ ePhysicalDeviceSparseImageFormatInfo2 = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2,\r
+ ePhysicalDeviceSparseImageFormatInfo2KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2,\r
+ ePhysicalDevicePointClippingProperties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES,\r
+ ePhysicalDevicePointClippingPropertiesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES,\r
+ eRenderPassInputAttachmentAspectCreateInfo = VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO,\r
+ eRenderPassInputAttachmentAspectCreateInfoKHR = VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO,\r
+ eImageViewUsageCreateInfo = VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO,\r
+ eImageViewUsageCreateInfoKHR = VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO,\r
+ ePipelineTessellationDomainOriginStateCreateInfo = VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO,\r
+ ePipelineTessellationDomainOriginStateCreateInfoKHR = VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO,\r
+ eRenderPassMultiviewCreateInfo = VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO,\r
+ eRenderPassMultiviewCreateInfoKHR = VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO,\r
+ ePhysicalDeviceMultiviewFeatures = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES,\r
+ ePhysicalDeviceMultiviewFeaturesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES,\r
+ ePhysicalDeviceMultiviewProperties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES,\r
+ ePhysicalDeviceMultiviewPropertiesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES,\r
+ ePhysicalDeviceVariablePointerFeatures = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES,\r
+ ePhysicalDeviceVariablePointerFeaturesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES,\r
+ eProtectedSubmitInfo = VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO,\r
+ ePhysicalDeviceProtectedMemoryFeatures = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES,\r
+ ePhysicalDeviceProtectedMemoryProperties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES,\r
+ eDeviceQueueInfo2 = VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2,\r
+ eSamplerYcbcrConversionCreateInfo = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO,\r
+ eSamplerYcbcrConversionCreateInfoKHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO,\r
+ eSamplerYcbcrConversionInfo = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO,\r
+ eSamplerYcbcrConversionInfoKHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO,\r
+ eBindImagePlaneMemoryInfo = VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO,\r
+ eBindImagePlaneMemoryInfoKHR = VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO,\r
+ eImagePlaneMemoryRequirementsInfo = VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO,\r
+ eImagePlaneMemoryRequirementsInfoKHR = VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO,\r
+ ePhysicalDeviceSamplerYcbcrConversionFeatures = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES,\r
+ ePhysicalDeviceSamplerYcbcrConversionFeaturesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES,\r
+ eSamplerYcbcrConversionImageFormatProperties = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES,\r
+ eSamplerYcbcrConversionImageFormatPropertiesKHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES,\r
+ eDescriptorUpdateTemplateCreateInfo = VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO,\r
+ eDescriptorUpdateTemplateCreateInfoKHR = VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO,\r
+ ePhysicalDeviceExternalImageFormatInfo = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO,\r
+ ePhysicalDeviceExternalImageFormatInfoKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO,\r
+ eExternalImageFormatProperties = VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES,\r
+ eExternalImageFormatPropertiesKHR = VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES,\r
+ ePhysicalDeviceExternalBufferInfo = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO,\r
+ ePhysicalDeviceExternalBufferInfoKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO,\r
+ eExternalBufferProperties = VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES,\r
+ eExternalBufferPropertiesKHR = VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES,\r
+ ePhysicalDeviceIdProperties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES,\r
+ ePhysicalDeviceIdPropertiesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES,\r
+ eExternalMemoryBufferCreateInfo = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO,\r
+ eExternalMemoryBufferCreateInfoKHR = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO,\r
+ eExternalMemoryImageCreateInfo = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO,\r
+ eExternalMemoryImageCreateInfoKHR = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO,\r
+ eExportMemoryAllocateInfo = VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO,\r
+ eExportMemoryAllocateInfoKHR = VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO,\r
+ ePhysicalDeviceExternalFenceInfo = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO,\r
+ ePhysicalDeviceExternalFenceInfoKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO,\r
+ eExternalFenceProperties = VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES,\r
+ eExternalFencePropertiesKHR = VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES,\r
+ eExportFenceCreateInfo = VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO,\r
+ eExportFenceCreateInfoKHR = VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO,\r
+ eExportSemaphoreCreateInfo = VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO,\r
+ eExportSemaphoreCreateInfoKHR = VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO,\r
+ ePhysicalDeviceExternalSemaphoreInfo = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO,\r
+ ePhysicalDeviceExternalSemaphoreInfoKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO,\r
+ eExternalSemaphoreProperties = VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES,\r
+ eExternalSemaphorePropertiesKHR = VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES,\r
+ ePhysicalDeviceMaintenance3Properties = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES,\r
+ ePhysicalDeviceMaintenance3PropertiesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES,\r
+ eDescriptorSetLayoutSupport = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT,\r
+ eDescriptorSetLayoutSupportKHR = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT,\r
+ ePhysicalDeviceShaderDrawParameterFeatures = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES,\r
+ eSwapchainCreateInfoKHR = VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR,\r
+ ePresentInfoKHR = VK_STRUCTURE_TYPE_PRESENT_INFO_KHR,\r
+ eDeviceGroupPresentCapabilitiesKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR,\r
+ eImageSwapchainCreateInfoKHR = VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR,\r
+ eBindImageMemorySwapchainInfoKHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR,\r
+ eAcquireNextImageInfoKHR = VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR,\r
+ eDeviceGroupPresentInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR,\r
+ eDeviceGroupSwapchainCreateInfoKHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR,\r
+ eDisplayModeCreateInfoKHR = VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR,\r
+ eDisplaySurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR,\r
+ eDisplayPresentInfoKHR = VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR,\r
+ eXlibSurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR,\r
+ eXcbSurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR,\r
+ eWaylandSurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR,\r
+ eMirSurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR,\r
+ eAndroidSurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR,\r
+ eWin32SurfaceCreateInfoKHR = VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR,\r
+ eDebugReportCallbackCreateInfoEXT = VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT,\r
+ ePipelineRasterizationStateRasterizationOrderAMD = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD,\r
+ eDebugMarkerObjectNameInfoEXT = VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT,\r
+ eDebugMarkerObjectTagInfoEXT = VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT,\r
+ eDebugMarkerMarkerInfoEXT = VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT,\r
+ eDedicatedAllocationImageCreateInfoNV = VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV,\r
+ eDedicatedAllocationBufferCreateInfoNV = VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV,\r
+ eDedicatedAllocationMemoryAllocateInfoNV = VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV,\r
+ eTextureLodGatherFormatPropertiesAMD = VK_STRUCTURE_TYPE_TEXTURE_LOD_GATHER_FORMAT_PROPERTIES_AMD,\r
+ eExternalMemoryImageCreateInfoNV = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV,\r
+ eExportMemoryAllocateInfoNV = VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV,\r
+ eImportMemoryWin32HandleInfoNV = VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV,\r
+ eExportMemoryWin32HandleInfoNV = VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV,\r
+ eWin32KeyedMutexAcquireReleaseInfoNV = VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV,\r
+ eValidationFlagsEXT = VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT,\r
+ eViSurfaceCreateInfoNN = VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN,\r
+ eImportMemoryWin32HandleInfoKHR = VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_KHR,\r
+ eExportMemoryWin32HandleInfoKHR = VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_KHR,\r
+ eMemoryWin32HandlePropertiesKHR = VK_STRUCTURE_TYPE_MEMORY_WIN32_HANDLE_PROPERTIES_KHR,\r
+ eMemoryGetWin32HandleInfoKHR = VK_STRUCTURE_TYPE_MEMORY_GET_WIN32_HANDLE_INFO_KHR,\r
+ eImportMemoryFdInfoKHR = VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR,\r
+ eMemoryFdPropertiesKHR = VK_STRUCTURE_TYPE_MEMORY_FD_PROPERTIES_KHR,\r
+ eMemoryGetFdInfoKHR = VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR,\r
+ eWin32KeyedMutexAcquireReleaseInfoKHR = VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_KHR,\r
+ eImportSemaphoreWin32HandleInfoKHR = VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR,\r
+ eExportSemaphoreWin32HandleInfoKHR = VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR,\r
+ eD3D12FenceSubmitInfoKHR = VK_STRUCTURE_TYPE_D3D12_FENCE_SUBMIT_INFO_KHR,\r
+ eSemaphoreGetWin32HandleInfoKHR = VK_STRUCTURE_TYPE_SEMAPHORE_GET_WIN32_HANDLE_INFO_KHR,\r
+ eImportSemaphoreFdInfoKHR = VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR,\r
+ eSemaphoreGetFdInfoKHR = VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR,\r
+ ePhysicalDevicePushDescriptorPropertiesKHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR,\r
+ ePresentRegionsKHR = VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR,\r
+ eObjectTableCreateInfoNVX = VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX,\r
+ eIndirectCommandsLayoutCreateInfoNVX = VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX,\r
+ eCmdProcessCommandsInfoNVX = VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX,\r
+ eCmdReserveSpaceForCommandsInfoNVX = VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX,\r
+ eDeviceGeneratedCommandsLimitsNVX = VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX,\r
+ eDeviceGeneratedCommandsFeaturesNVX = VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX,\r
+ ePipelineViewportWScalingStateCreateInfoNV = VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV,\r
+ eSurfaceCapabilities2EXT = VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT,\r
+ eDisplayPowerInfoEXT = VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT,\r
+ eDeviceEventInfoEXT = VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT,\r
+ eDisplayEventInfoEXT = VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT,\r
+ eSwapchainCounterCreateInfoEXT = VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT,\r
+ ePresentTimesInfoGOOGLE = VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE,\r
+ ePhysicalDeviceMultiviewPerViewAttributesPropertiesNVX = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX,\r
+ ePipelineViewportSwizzleStateCreateInfoNV = VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV,\r
+ ePhysicalDeviceDiscardRectanglePropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT,\r
+ ePipelineDiscardRectangleStateCreateInfoEXT = VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT,\r
+ ePhysicalDeviceConservativeRasterizationPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT,\r
+ ePipelineRasterizationConservativeStateCreateInfoEXT = VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT,\r
+ eHdrMetadataEXT = VK_STRUCTURE_TYPE_HDR_METADATA_EXT,\r
+ eSharedPresentSurfaceCapabilitiesKHR = VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR,\r
+ eImportFenceWin32HandleInfoKHR = VK_STRUCTURE_TYPE_IMPORT_FENCE_WIN32_HANDLE_INFO_KHR,\r
+ eExportFenceWin32HandleInfoKHR = VK_STRUCTURE_TYPE_EXPORT_FENCE_WIN32_HANDLE_INFO_KHR,\r
+ eFenceGetWin32HandleInfoKHR = VK_STRUCTURE_TYPE_FENCE_GET_WIN32_HANDLE_INFO_KHR,\r
+ eImportFenceFdInfoKHR = VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR,\r
+ eFenceGetFdInfoKHR = VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR,\r
+ ePhysicalDeviceSurfaceInfo2KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR,\r
+ eSurfaceCapabilities2KHR = VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR,\r
+ eSurfaceFormat2KHR = VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR,\r
+ eIosSurfaceCreateInfoMVK = VK_STRUCTURE_TYPE_IOS_SURFACE_CREATE_INFO_MVK,\r
+ eMacosSurfaceCreateInfoMVK = VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK,\r
+ eDebugUtilsObjectNameInfoEXT = VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT,\r
+ eDebugUtilsObjectTagInfoEXT = VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT,\r
+ eDebugUtilsLabelEXT = VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT,\r
+ eDebugUtilsMessengerCallbackDataEXT = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT,\r
+ eDebugUtilsMessengerCreateInfoEXT = VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT,\r
+ eAndroidHardwareBufferUsageANDROID = VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_USAGE_ANDROID,\r
+ eAndroidHardwareBufferPropertiesANDROID = VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_PROPERTIES_ANDROID,\r
+ eAndroidHardwareBufferFormatPropertiesANDROID = VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_FORMAT_PROPERTIES_ANDROID,\r
+ eImportAndroidHardwareBufferInfoANDROID = VK_STRUCTURE_TYPE_IMPORT_ANDROID_HARDWARE_BUFFER_INFO_ANDROID,\r
+ eMemoryGetAndroidHardwareBufferInfoANDROID = VK_STRUCTURE_TYPE_MEMORY_GET_ANDROID_HARDWARE_BUFFER_INFO_ANDROID,\r
+ eExternalFormatANDROID = VK_STRUCTURE_TYPE_EXTERNAL_FORMAT_ANDROID,\r
+ ePhysicalDeviceSamplerFilterMinmaxPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT,\r
+ eSamplerReductionModeCreateInfoEXT = VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT,\r
+ eSampleLocationsInfoEXT = VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT,\r
+ eRenderPassSampleLocationsBeginInfoEXT = VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT,\r
+ ePipelineSampleLocationsStateCreateInfoEXT = VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT,\r
+ ePhysicalDeviceSampleLocationsPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT,\r
+ eMultisamplePropertiesEXT = VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT,\r
+ eImageFormatListCreateInfoKHR = VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR,\r
+ ePhysicalDeviceBlendOperationAdvancedFeaturesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT,\r
+ ePhysicalDeviceBlendOperationAdvancedPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT,\r
+ ePipelineColorBlendAdvancedStateCreateInfoEXT = VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT,\r
+ ePipelineCoverageToColorStateCreateInfoNV = VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV,\r
+ ePipelineCoverageModulationStateCreateInfoNV = VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV,\r
+ eValidationCacheCreateInfoEXT = VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT,\r
+ eShaderModuleValidationCacheCreateInfoEXT = VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT,\r
+ eDescriptorSetLayoutBindingFlagsCreateInfoEXT = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_BINDING_FLAGS_CREATE_INFO_EXT,\r
+ ePhysicalDeviceDescriptorIndexingFeaturesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_FEATURES_EXT,\r
+ ePhysicalDeviceDescriptorIndexingPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_PROPERTIES_EXT,\r
+ eDescriptorSetVariableDescriptorCountAllocateInfoEXT = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_ALLOCATE_INFO_EXT,\r
+ eDescriptorSetVariableDescriptorCountLayoutSupportEXT = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_LAYOUT_SUPPORT_EXT,\r
+ eDeviceQueueGlobalPriorityCreateInfoEXT = VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT,\r
+ eImportMemoryHostPointerInfoEXT = VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT,\r
+ eMemoryHostPointerPropertiesEXT = VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT,\r
+ ePhysicalDeviceExternalMemoryHostPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT,\r
+ ePhysicalDeviceShaderCorePropertiesAMD = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_CORE_PROPERTIES_AMD,\r
+ ePhysicalDeviceVertexAttributeDivisorPropertiesEXT = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT,\r
+ ePipelineVertexInputDivisorStateCreateInfoEXT = VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT\r
+ };\r
+\r
+ struct ApplicationInfo\r
+ {\r
+ ApplicationInfo( const char* pApplicationName_ = nullptr, uint32_t applicationVersion_ = 0, const char* pEngineName_ = nullptr, uint32_t engineVersion_ = 0, uint32_t apiVersion_ = 0 )\r
+ : pApplicationName( pApplicationName_ )\r
+ , applicationVersion( applicationVersion_ )\r
+ , pEngineName( pEngineName_ )\r
+ , engineVersion( engineVersion_ )\r
+ , apiVersion( apiVersion_ )\r
+ {\r
+ }\r
+\r
+ ApplicationInfo( VkApplicationInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ApplicationInfo ) );\r
+ }\r
+\r
+ ApplicationInfo& operator=( VkApplicationInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ApplicationInfo ) );\r
+ return *this;\r
+ }\r
+ ApplicationInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ApplicationInfo& setPApplicationName( const char* pApplicationName_ )\r
+ {\r
+ pApplicationName = pApplicationName_;\r
+ return *this;\r
+ }\r
+\r
+ ApplicationInfo& setApplicationVersion( uint32_t applicationVersion_ )\r
+ {\r
+ applicationVersion = applicationVersion_;\r
+ return *this;\r
+ }\r
+\r
+ ApplicationInfo& setPEngineName( const char* pEngineName_ )\r
+ {\r
+ pEngineName = pEngineName_;\r
+ return *this;\r
+ }\r
+\r
+ ApplicationInfo& setEngineVersion( uint32_t engineVersion_ )\r
+ {\r
+ engineVersion = engineVersion_;\r
+ return *this;\r
+ }\r
+\r
+ ApplicationInfo& setApiVersion( uint32_t apiVersion_ )\r
+ {\r
+ apiVersion = apiVersion_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkApplicationInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkApplicationInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ApplicationInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pApplicationName == rhs.pApplicationName )\r
+ && ( applicationVersion == rhs.applicationVersion )\r
+ && ( pEngineName == rhs.pEngineName )\r
+ && ( engineVersion == rhs.engineVersion )\r
+ && ( apiVersion == rhs.apiVersion );\r
+ }\r
+\r
+ bool operator!=( ApplicationInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eApplicationInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const char* pApplicationName;\r
+ uint32_t applicationVersion;\r
+ const char* pEngineName;\r
+ uint32_t engineVersion;\r
+ uint32_t apiVersion;\r
+ };\r
+ static_assert( sizeof( ApplicationInfo ) == sizeof( VkApplicationInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct InstanceCreateInfo\r
+ {\r
+ InstanceCreateInfo( InstanceCreateFlags flags_ = InstanceCreateFlags(), const ApplicationInfo* pApplicationInfo_ = nullptr, uint32_t enabledLayerCount_ = 0, const char* const* ppEnabledLayerNames_ = nullptr, uint32_t enabledExtensionCount_ = 0, const char* const* ppEnabledExtensionNames_ = nullptr )\r
+ : flags( flags_ )\r
+ , pApplicationInfo( pApplicationInfo_ )\r
+ , enabledLayerCount( enabledLayerCount_ )\r
+ , ppEnabledLayerNames( ppEnabledLayerNames_ )\r
+ , enabledExtensionCount( enabledExtensionCount_ )\r
+ , ppEnabledExtensionNames( ppEnabledExtensionNames_ )\r
+ {\r
+ }\r
+\r
+ InstanceCreateInfo( VkInstanceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( InstanceCreateInfo ) );\r
+ }\r
+\r
+ InstanceCreateInfo& operator=( VkInstanceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( InstanceCreateInfo ) );\r
+ return *this;\r
+ }\r
+ InstanceCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ InstanceCreateInfo& setFlags( InstanceCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ InstanceCreateInfo& setPApplicationInfo( const ApplicationInfo* pApplicationInfo_ )\r
+ {\r
+ pApplicationInfo = pApplicationInfo_;\r
+ return *this;\r
+ }\r
+\r
+ InstanceCreateInfo& setEnabledLayerCount( uint32_t enabledLayerCount_ )\r
+ {\r
+ enabledLayerCount = enabledLayerCount_;\r
+ return *this;\r
+ }\r
+\r
+ InstanceCreateInfo& setPpEnabledLayerNames( const char* const* ppEnabledLayerNames_ )\r
+ {\r
+ ppEnabledLayerNames = ppEnabledLayerNames_;\r
+ return *this;\r
+ }\r
+\r
+ InstanceCreateInfo& setEnabledExtensionCount( uint32_t enabledExtensionCount_ )\r
+ {\r
+ enabledExtensionCount = enabledExtensionCount_;\r
+ return *this;\r
+ }\r
+\r
+ InstanceCreateInfo& setPpEnabledExtensionNames( const char* const* ppEnabledExtensionNames_ )\r
+ {\r
+ ppEnabledExtensionNames = ppEnabledExtensionNames_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkInstanceCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkInstanceCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( InstanceCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( pApplicationInfo == rhs.pApplicationInfo )\r
+ && ( enabledLayerCount == rhs.enabledLayerCount )\r
+ && ( ppEnabledLayerNames == rhs.ppEnabledLayerNames )\r
+ && ( enabledExtensionCount == rhs.enabledExtensionCount )\r
+ && ( ppEnabledExtensionNames == rhs.ppEnabledExtensionNames );\r
+ }\r
+\r
+ bool operator!=( InstanceCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eInstanceCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ InstanceCreateFlags flags;\r
+ const ApplicationInfo* pApplicationInfo;\r
+ uint32_t enabledLayerCount;\r
+ const char* const* ppEnabledLayerNames;\r
+ uint32_t enabledExtensionCount;\r
+ const char* const* ppEnabledExtensionNames;\r
+ };\r
+ static_assert( sizeof( InstanceCreateInfo ) == sizeof( VkInstanceCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct MemoryAllocateInfo\r
+ {\r
+ MemoryAllocateInfo( DeviceSize allocationSize_ = 0, uint32_t memoryTypeIndex_ = 0 )\r
+ : allocationSize( allocationSize_ )\r
+ , memoryTypeIndex( memoryTypeIndex_ )\r
+ {\r
+ }\r
+\r
+ MemoryAllocateInfo( VkMemoryAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryAllocateInfo ) );\r
+ }\r
+\r
+ MemoryAllocateInfo& operator=( VkMemoryAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryAllocateInfo ) );\r
+ return *this;\r
+ }\r
+ MemoryAllocateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryAllocateInfo& setAllocationSize( DeviceSize allocationSize_ )\r
+ {\r
+ allocationSize = allocationSize_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryAllocateInfo& setMemoryTypeIndex( uint32_t memoryTypeIndex_ )\r
+ {\r
+ memoryTypeIndex = memoryTypeIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryAllocateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryAllocateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryAllocateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( allocationSize == rhs.allocationSize )\r
+ && ( memoryTypeIndex == rhs.memoryTypeIndex );\r
+ }\r
+\r
+ bool operator!=( MemoryAllocateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryAllocateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceSize allocationSize;\r
+ uint32_t memoryTypeIndex;\r
+ };\r
+ static_assert( sizeof( MemoryAllocateInfo ) == sizeof( VkMemoryAllocateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct MappedMemoryRange\r
+ {\r
+ MappedMemoryRange( DeviceMemory memory_ = DeviceMemory(), DeviceSize offset_ = 0, DeviceSize size_ = 0 )\r
+ : memory( memory_ )\r
+ , offset( offset_ )\r
+ , size( size_ )\r
+ {\r
+ }\r
+\r
+ MappedMemoryRange( VkMappedMemoryRange const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MappedMemoryRange ) );\r
+ }\r
+\r
+ MappedMemoryRange& operator=( VkMappedMemoryRange const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MappedMemoryRange ) );\r
+ return *this;\r
+ }\r
+ MappedMemoryRange& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MappedMemoryRange& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ MappedMemoryRange& setOffset( DeviceSize offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ MappedMemoryRange& setSize( DeviceSize size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMappedMemoryRange&() const\r
+ {\r
+ return *reinterpret_cast<const VkMappedMemoryRange*>(this);\r
+ }\r
+\r
+ bool operator==( MappedMemoryRange const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memory == rhs.memory )\r
+ && ( offset == rhs.offset )\r
+ && ( size == rhs.size );\r
+ }\r
+\r
+ bool operator!=( MappedMemoryRange const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMappedMemoryRange;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceMemory memory;\r
+ DeviceSize offset;\r
+ DeviceSize size;\r
+ };\r
+ static_assert( sizeof( MappedMemoryRange ) == sizeof( VkMappedMemoryRange ), "struct and wrapper have different size!" );\r
+\r
+ struct WriteDescriptorSet\r
+ {\r
+ WriteDescriptorSet( DescriptorSet dstSet_ = DescriptorSet(), uint32_t dstBinding_ = 0, uint32_t dstArrayElement_ = 0, uint32_t descriptorCount_ = 0, DescriptorType descriptorType_ = DescriptorType::eSampler, const DescriptorImageInfo* pImageInfo_ = nullptr, const DescriptorBufferInfo* pBufferInfo_ = nullptr, const BufferView* pTexelBufferView_ = nullptr )\r
+ : dstSet( dstSet_ )\r
+ , dstBinding( dstBinding_ )\r
+ , dstArrayElement( dstArrayElement_ )\r
+ , descriptorCount( descriptorCount_ )\r
+ , descriptorType( descriptorType_ )\r
+ , pImageInfo( pImageInfo_ )\r
+ , pBufferInfo( pBufferInfo_ )\r
+ , pTexelBufferView( pTexelBufferView_ )\r
+ {\r
+ }\r
+\r
+ WriteDescriptorSet( VkWriteDescriptorSet const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( WriteDescriptorSet ) );\r
+ }\r
+\r
+ WriteDescriptorSet& operator=( VkWriteDescriptorSet const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( WriteDescriptorSet ) );\r
+ return *this;\r
+ }\r
+ WriteDescriptorSet& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setDstSet( DescriptorSet dstSet_ )\r
+ {\r
+ dstSet = dstSet_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setDstBinding( uint32_t dstBinding_ )\r
+ {\r
+ dstBinding = dstBinding_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setDstArrayElement( uint32_t dstArrayElement_ )\r
+ {\r
+ dstArrayElement = dstArrayElement_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setDescriptorCount( uint32_t descriptorCount_ )\r
+ {\r
+ descriptorCount = descriptorCount_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setDescriptorType( DescriptorType descriptorType_ )\r
+ {\r
+ descriptorType = descriptorType_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setPImageInfo( const DescriptorImageInfo* pImageInfo_ )\r
+ {\r
+ pImageInfo = pImageInfo_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setPBufferInfo( const DescriptorBufferInfo* pBufferInfo_ )\r
+ {\r
+ pBufferInfo = pBufferInfo_;\r
+ return *this;\r
+ }\r
+\r
+ WriteDescriptorSet& setPTexelBufferView( const BufferView* pTexelBufferView_ )\r
+ {\r
+ pTexelBufferView = pTexelBufferView_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkWriteDescriptorSet&() const\r
+ {\r
+ return *reinterpret_cast<const VkWriteDescriptorSet*>(this);\r
+ }\r
+\r
+ bool operator==( WriteDescriptorSet const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( dstSet == rhs.dstSet )\r
+ && ( dstBinding == rhs.dstBinding )\r
+ && ( dstArrayElement == rhs.dstArrayElement )\r
+ && ( descriptorCount == rhs.descriptorCount )\r
+ && ( descriptorType == rhs.descriptorType )\r
+ && ( pImageInfo == rhs.pImageInfo )\r
+ && ( pBufferInfo == rhs.pBufferInfo )\r
+ && ( pTexelBufferView == rhs.pTexelBufferView );\r
+ }\r
+\r
+ bool operator!=( WriteDescriptorSet const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eWriteDescriptorSet;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DescriptorSet dstSet;\r
+ uint32_t dstBinding;\r
+ uint32_t dstArrayElement;\r
+ uint32_t descriptorCount;\r
+ DescriptorType descriptorType;\r
+ const DescriptorImageInfo* pImageInfo;\r
+ const DescriptorBufferInfo* pBufferInfo;\r
+ const BufferView* pTexelBufferView;\r
+ };\r
+ static_assert( sizeof( WriteDescriptorSet ) == sizeof( VkWriteDescriptorSet ), "struct and wrapper have different size!" );\r
+\r
+ struct CopyDescriptorSet\r
+ {\r
+ CopyDescriptorSet( DescriptorSet srcSet_ = DescriptorSet(), uint32_t srcBinding_ = 0, uint32_t srcArrayElement_ = 0, DescriptorSet dstSet_ = DescriptorSet(), uint32_t dstBinding_ = 0, uint32_t dstArrayElement_ = 0, uint32_t descriptorCount_ = 0 )\r
+ : srcSet( srcSet_ )\r
+ , srcBinding( srcBinding_ )\r
+ , srcArrayElement( srcArrayElement_ )\r
+ , dstSet( dstSet_ )\r
+ , dstBinding( dstBinding_ )\r
+ , dstArrayElement( dstArrayElement_ )\r
+ , descriptorCount( descriptorCount_ )\r
+ {\r
+ }\r
+\r
+ CopyDescriptorSet( VkCopyDescriptorSet const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CopyDescriptorSet ) );\r
+ }\r
+\r
+ CopyDescriptorSet& operator=( VkCopyDescriptorSet const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CopyDescriptorSet ) );\r
+ return *this;\r
+ }\r
+ CopyDescriptorSet& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setSrcSet( DescriptorSet srcSet_ )\r
+ {\r
+ srcSet = srcSet_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setSrcBinding( uint32_t srcBinding_ )\r
+ {\r
+ srcBinding = srcBinding_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setSrcArrayElement( uint32_t srcArrayElement_ )\r
+ {\r
+ srcArrayElement = srcArrayElement_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setDstSet( DescriptorSet dstSet_ )\r
+ {\r
+ dstSet = dstSet_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setDstBinding( uint32_t dstBinding_ )\r
+ {\r
+ dstBinding = dstBinding_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setDstArrayElement( uint32_t dstArrayElement_ )\r
+ {\r
+ dstArrayElement = dstArrayElement_;\r
+ return *this;\r
+ }\r
+\r
+ CopyDescriptorSet& setDescriptorCount( uint32_t descriptorCount_ )\r
+ {\r
+ descriptorCount = descriptorCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCopyDescriptorSet&() const\r
+ {\r
+ return *reinterpret_cast<const VkCopyDescriptorSet*>(this);\r
+ }\r
+\r
+ bool operator==( CopyDescriptorSet const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( srcSet == rhs.srcSet )\r
+ && ( srcBinding == rhs.srcBinding )\r
+ && ( srcArrayElement == rhs.srcArrayElement )\r
+ && ( dstSet == rhs.dstSet )\r
+ && ( dstBinding == rhs.dstBinding )\r
+ && ( dstArrayElement == rhs.dstArrayElement )\r
+ && ( descriptorCount == rhs.descriptorCount );\r
+ }\r
+\r
+ bool operator!=( CopyDescriptorSet const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCopyDescriptorSet;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DescriptorSet srcSet;\r
+ uint32_t srcBinding;\r
+ uint32_t srcArrayElement;\r
+ DescriptorSet dstSet;\r
+ uint32_t dstBinding;\r
+ uint32_t dstArrayElement;\r
+ uint32_t descriptorCount;\r
+ };\r
+ static_assert( sizeof( CopyDescriptorSet ) == sizeof( VkCopyDescriptorSet ), "struct and wrapper have different size!" );\r
+\r
+ struct BufferViewCreateInfo\r
+ {\r
+ BufferViewCreateInfo( BufferViewCreateFlags flags_ = BufferViewCreateFlags(), Buffer buffer_ = Buffer(), Format format_ = Format::eUndefined, DeviceSize offset_ = 0, DeviceSize range_ = 0 )\r
+ : flags( flags_ )\r
+ , buffer( buffer_ )\r
+ , format( format_ )\r
+ , offset( offset_ )\r
+ , range( range_ )\r
+ {\r
+ }\r
+\r
+ BufferViewCreateInfo( VkBufferViewCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferViewCreateInfo ) );\r
+ }\r
+\r
+ BufferViewCreateInfo& operator=( VkBufferViewCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferViewCreateInfo ) );\r
+ return *this;\r
+ }\r
+ BufferViewCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BufferViewCreateInfo& setFlags( BufferViewCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ BufferViewCreateInfo& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ BufferViewCreateInfo& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ BufferViewCreateInfo& setOffset( DeviceSize offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ BufferViewCreateInfo& setRange( DeviceSize range_ )\r
+ {\r
+ range = range_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBufferViewCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBufferViewCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BufferViewCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( buffer == rhs.buffer )\r
+ && ( format == rhs.format )\r
+ && ( offset == rhs.offset )\r
+ && ( range == rhs.range );\r
+ }\r
+\r
+ bool operator!=( BufferViewCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBufferViewCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ BufferViewCreateFlags flags;\r
+ Buffer buffer;\r
+ Format format;\r
+ DeviceSize offset;\r
+ DeviceSize range;\r
+ };\r
+ static_assert( sizeof( BufferViewCreateInfo ) == sizeof( VkBufferViewCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct ShaderModuleCreateInfo\r
+ {\r
+ ShaderModuleCreateInfo( ShaderModuleCreateFlags flags_ = ShaderModuleCreateFlags(), size_t codeSize_ = 0, const uint32_t* pCode_ = nullptr )\r
+ : flags( flags_ )\r
+ , codeSize( codeSize_ )\r
+ , pCode( pCode_ )\r
+ {\r
+ }\r
+\r
+ ShaderModuleCreateInfo( VkShaderModuleCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ShaderModuleCreateInfo ) );\r
+ }\r
+\r
+ ShaderModuleCreateInfo& operator=( VkShaderModuleCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ShaderModuleCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ShaderModuleCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ShaderModuleCreateInfo& setFlags( ShaderModuleCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ShaderModuleCreateInfo& setCodeSize( size_t codeSize_ )\r
+ {\r
+ codeSize = codeSize_;\r
+ return *this;\r
+ }\r
+\r
+ ShaderModuleCreateInfo& setPCode( const uint32_t* pCode_ )\r
+ {\r
+ pCode = pCode_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkShaderModuleCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkShaderModuleCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ShaderModuleCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( codeSize == rhs.codeSize )\r
+ && ( pCode == rhs.pCode );\r
+ }\r
+\r
+ bool operator!=( ShaderModuleCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eShaderModuleCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ShaderModuleCreateFlags flags;\r
+ size_t codeSize;\r
+ const uint32_t* pCode;\r
+ };\r
+ static_assert( sizeof( ShaderModuleCreateInfo ) == sizeof( VkShaderModuleCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct DescriptorSetAllocateInfo\r
+ {\r
+ DescriptorSetAllocateInfo( DescriptorPool descriptorPool_ = DescriptorPool(), uint32_t descriptorSetCount_ = 0, const DescriptorSetLayout* pSetLayouts_ = nullptr )\r
+ : descriptorPool( descriptorPool_ )\r
+ , descriptorSetCount( descriptorSetCount_ )\r
+ , pSetLayouts( pSetLayouts_ )\r
+ {\r
+ }\r
+\r
+ DescriptorSetAllocateInfo( VkDescriptorSetAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetAllocateInfo ) );\r
+ }\r
+\r
+ DescriptorSetAllocateInfo& operator=( VkDescriptorSetAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetAllocateInfo ) );\r
+ return *this;\r
+ }\r
+ DescriptorSetAllocateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetAllocateInfo& setDescriptorPool( DescriptorPool descriptorPool_ )\r
+ {\r
+ descriptorPool = descriptorPool_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetAllocateInfo& setDescriptorSetCount( uint32_t descriptorSetCount_ )\r
+ {\r
+ descriptorSetCount = descriptorSetCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetAllocateInfo& setPSetLayouts( const DescriptorSetLayout* pSetLayouts_ )\r
+ {\r
+ pSetLayouts = pSetLayouts_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorSetAllocateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetAllocateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetAllocateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( descriptorPool == rhs.descriptorPool )\r
+ && ( descriptorSetCount == rhs.descriptorSetCount )\r
+ && ( pSetLayouts == rhs.pSetLayouts );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetAllocateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorSetAllocateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DescriptorPool descriptorPool;\r
+ uint32_t descriptorSetCount;\r
+ const DescriptorSetLayout* pSetLayouts;\r
+ };\r
+ static_assert( sizeof( DescriptorSetAllocateInfo ) == sizeof( VkDescriptorSetAllocateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineVertexInputStateCreateInfo\r
+ {\r
+ PipelineVertexInputStateCreateInfo( PipelineVertexInputStateCreateFlags flags_ = PipelineVertexInputStateCreateFlags(), uint32_t vertexBindingDescriptionCount_ = 0, const VertexInputBindingDescription* pVertexBindingDescriptions_ = nullptr, uint32_t vertexAttributeDescriptionCount_ = 0, const VertexInputAttributeDescription* pVertexAttributeDescriptions_ = nullptr )\r
+ : flags( flags_ )\r
+ , vertexBindingDescriptionCount( vertexBindingDescriptionCount_ )\r
+ , pVertexBindingDescriptions( pVertexBindingDescriptions_ )\r
+ , vertexAttributeDescriptionCount( vertexAttributeDescriptionCount_ )\r
+ , pVertexAttributeDescriptions( pVertexAttributeDescriptions_ )\r
+ {\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo( VkPipelineVertexInputStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineVertexInputStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo& operator=( VkPipelineVertexInputStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineVertexInputStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineVertexInputStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo& setFlags( PipelineVertexInputStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo& setVertexBindingDescriptionCount( uint32_t vertexBindingDescriptionCount_ )\r
+ {\r
+ vertexBindingDescriptionCount = vertexBindingDescriptionCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo& setPVertexBindingDescriptions( const VertexInputBindingDescription* pVertexBindingDescriptions_ )\r
+ {\r
+ pVertexBindingDescriptions = pVertexBindingDescriptions_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo& setVertexAttributeDescriptionCount( uint32_t vertexAttributeDescriptionCount_ )\r
+ {\r
+ vertexAttributeDescriptionCount = vertexAttributeDescriptionCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputStateCreateInfo& setPVertexAttributeDescriptions( const VertexInputAttributeDescription* pVertexAttributeDescriptions_ )\r
+ {\r
+ pVertexAttributeDescriptions = pVertexAttributeDescriptions_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineVertexInputStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineVertexInputStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineVertexInputStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( vertexBindingDescriptionCount == rhs.vertexBindingDescriptionCount )\r
+ && ( pVertexBindingDescriptions == rhs.pVertexBindingDescriptions )\r
+ && ( vertexAttributeDescriptionCount == rhs.vertexAttributeDescriptionCount )\r
+ && ( pVertexAttributeDescriptions == rhs.pVertexAttributeDescriptions );\r
+ }\r
+\r
+ bool operator!=( PipelineVertexInputStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineVertexInputStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineVertexInputStateCreateFlags flags;\r
+ uint32_t vertexBindingDescriptionCount;\r
+ const VertexInputBindingDescription* pVertexBindingDescriptions;\r
+ uint32_t vertexAttributeDescriptionCount;\r
+ const VertexInputAttributeDescription* pVertexAttributeDescriptions;\r
+ };\r
+ static_assert( sizeof( PipelineVertexInputStateCreateInfo ) == sizeof( VkPipelineVertexInputStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineInputAssemblyStateCreateInfo\r
+ {\r
+ PipelineInputAssemblyStateCreateInfo( PipelineInputAssemblyStateCreateFlags flags_ = PipelineInputAssemblyStateCreateFlags(), PrimitiveTopology topology_ = PrimitiveTopology::ePointList, Bool32 primitiveRestartEnable_ = 0 )\r
+ : flags( flags_ )\r
+ , topology( topology_ )\r
+ , primitiveRestartEnable( primitiveRestartEnable_ )\r
+ {\r
+ }\r
+\r
+ PipelineInputAssemblyStateCreateInfo( VkPipelineInputAssemblyStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineInputAssemblyStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineInputAssemblyStateCreateInfo& operator=( VkPipelineInputAssemblyStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineInputAssemblyStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineInputAssemblyStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineInputAssemblyStateCreateInfo& setFlags( PipelineInputAssemblyStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineInputAssemblyStateCreateInfo& setTopology( PrimitiveTopology topology_ )\r
+ {\r
+ topology = topology_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineInputAssemblyStateCreateInfo& setPrimitiveRestartEnable( Bool32 primitiveRestartEnable_ )\r
+ {\r
+ primitiveRestartEnable = primitiveRestartEnable_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineInputAssemblyStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineInputAssemblyStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineInputAssemblyStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( topology == rhs.topology )\r
+ && ( primitiveRestartEnable == rhs.primitiveRestartEnable );\r
+ }\r
+\r
+ bool operator!=( PipelineInputAssemblyStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineInputAssemblyStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineInputAssemblyStateCreateFlags flags;\r
+ PrimitiveTopology topology;\r
+ Bool32 primitiveRestartEnable;\r
+ };\r
+ static_assert( sizeof( PipelineInputAssemblyStateCreateInfo ) == sizeof( VkPipelineInputAssemblyStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineTessellationStateCreateInfo\r
+ {\r
+ PipelineTessellationStateCreateInfo( PipelineTessellationStateCreateFlags flags_ = PipelineTessellationStateCreateFlags(), uint32_t patchControlPoints_ = 0 )\r
+ : flags( flags_ )\r
+ , patchControlPoints( patchControlPoints_ )\r
+ {\r
+ }\r
+\r
+ PipelineTessellationStateCreateInfo( VkPipelineTessellationStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineTessellationStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineTessellationStateCreateInfo& operator=( VkPipelineTessellationStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineTessellationStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineTessellationStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineTessellationStateCreateInfo& setFlags( PipelineTessellationStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineTessellationStateCreateInfo& setPatchControlPoints( uint32_t patchControlPoints_ )\r
+ {\r
+ patchControlPoints = patchControlPoints_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineTessellationStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineTessellationStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineTessellationStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( patchControlPoints == rhs.patchControlPoints );\r
+ }\r
+\r
+ bool operator!=( PipelineTessellationStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineTessellationStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineTessellationStateCreateFlags flags;\r
+ uint32_t patchControlPoints;\r
+ };\r
+ static_assert( sizeof( PipelineTessellationStateCreateInfo ) == sizeof( VkPipelineTessellationStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineViewportStateCreateInfo\r
+ {\r
+ PipelineViewportStateCreateInfo( PipelineViewportStateCreateFlags flags_ = PipelineViewportStateCreateFlags(), uint32_t viewportCount_ = 0, const Viewport* pViewports_ = nullptr, uint32_t scissorCount_ = 0, const Rect2D* pScissors_ = nullptr )\r
+ : flags( flags_ )\r
+ , viewportCount( viewportCount_ )\r
+ , pViewports( pViewports_ )\r
+ , scissorCount( scissorCount_ )\r
+ , pScissors( pScissors_ )\r
+ {\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo( VkPipelineViewportStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineViewportStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo& operator=( VkPipelineViewportStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineViewportStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineViewportStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo& setFlags( PipelineViewportStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo& setViewportCount( uint32_t viewportCount_ )\r
+ {\r
+ viewportCount = viewportCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo& setPViewports( const Viewport* pViewports_ )\r
+ {\r
+ pViewports = pViewports_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo& setScissorCount( uint32_t scissorCount_ )\r
+ {\r
+ scissorCount = scissorCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportStateCreateInfo& setPScissors( const Rect2D* pScissors_ )\r
+ {\r
+ pScissors = pScissors_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineViewportStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineViewportStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineViewportStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( viewportCount == rhs.viewportCount )\r
+ && ( pViewports == rhs.pViewports )\r
+ && ( scissorCount == rhs.scissorCount )\r
+ && ( pScissors == rhs.pScissors );\r
+ }\r
+\r
+ bool operator!=( PipelineViewportStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineViewportStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineViewportStateCreateFlags flags;\r
+ uint32_t viewportCount;\r
+ const Viewport* pViewports;\r
+ uint32_t scissorCount;\r
+ const Rect2D* pScissors;\r
+ };\r
+ static_assert( sizeof( PipelineViewportStateCreateInfo ) == sizeof( VkPipelineViewportStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineRasterizationStateCreateInfo\r
+ {\r
+ PipelineRasterizationStateCreateInfo( PipelineRasterizationStateCreateFlags flags_ = PipelineRasterizationStateCreateFlags(), Bool32 depthClampEnable_ = 0, Bool32 rasterizerDiscardEnable_ = 0, PolygonMode polygonMode_ = PolygonMode::eFill, CullModeFlags cullMode_ = CullModeFlags(), FrontFace frontFace_ = FrontFace::eCounterClockwise, Bool32 depthBiasEnable_ = 0, float depthBiasConstantFactor_ = 0, float depthBiasClamp_ = 0, float depthBiasSlopeFactor_ = 0, float lineWidth_ = 0 )\r
+ : flags( flags_ )\r
+ , depthClampEnable( depthClampEnable_ )\r
+ , rasterizerDiscardEnable( rasterizerDiscardEnable_ )\r
+ , polygonMode( polygonMode_ )\r
+ , cullMode( cullMode_ )\r
+ , frontFace( frontFace_ )\r
+ , depthBiasEnable( depthBiasEnable_ )\r
+ , depthBiasConstantFactor( depthBiasConstantFactor_ )\r
+ , depthBiasClamp( depthBiasClamp_ )\r
+ , depthBiasSlopeFactor( depthBiasSlopeFactor_ )\r
+ , lineWidth( lineWidth_ )\r
+ {\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo( VkPipelineRasterizationStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineRasterizationStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& operator=( VkPipelineRasterizationStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineRasterizationStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineRasterizationStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setFlags( PipelineRasterizationStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setDepthClampEnable( Bool32 depthClampEnable_ )\r
+ {\r
+ depthClampEnable = depthClampEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setRasterizerDiscardEnable( Bool32 rasterizerDiscardEnable_ )\r
+ {\r
+ rasterizerDiscardEnable = rasterizerDiscardEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setPolygonMode( PolygonMode polygonMode_ )\r
+ {\r
+ polygonMode = polygonMode_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setCullMode( CullModeFlags cullMode_ )\r
+ {\r
+ cullMode = cullMode_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setFrontFace( FrontFace frontFace_ )\r
+ {\r
+ frontFace = frontFace_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setDepthBiasEnable( Bool32 depthBiasEnable_ )\r
+ {\r
+ depthBiasEnable = depthBiasEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setDepthBiasConstantFactor( float depthBiasConstantFactor_ )\r
+ {\r
+ depthBiasConstantFactor = depthBiasConstantFactor_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setDepthBiasClamp( float depthBiasClamp_ )\r
+ {\r
+ depthBiasClamp = depthBiasClamp_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setDepthBiasSlopeFactor( float depthBiasSlopeFactor_ )\r
+ {\r
+ depthBiasSlopeFactor = depthBiasSlopeFactor_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateCreateInfo& setLineWidth( float lineWidth_ )\r
+ {\r
+ lineWidth = lineWidth_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineRasterizationStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineRasterizationStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineRasterizationStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( depthClampEnable == rhs.depthClampEnable )\r
+ && ( rasterizerDiscardEnable == rhs.rasterizerDiscardEnable )\r
+ && ( polygonMode == rhs.polygonMode )\r
+ && ( cullMode == rhs.cullMode )\r
+ && ( frontFace == rhs.frontFace )\r
+ && ( depthBiasEnable == rhs.depthBiasEnable )\r
+ && ( depthBiasConstantFactor == rhs.depthBiasConstantFactor )\r
+ && ( depthBiasClamp == rhs.depthBiasClamp )\r
+ && ( depthBiasSlopeFactor == rhs.depthBiasSlopeFactor )\r
+ && ( lineWidth == rhs.lineWidth );\r
+ }\r
+\r
+ bool operator!=( PipelineRasterizationStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineRasterizationStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineRasterizationStateCreateFlags flags;\r
+ Bool32 depthClampEnable;\r
+ Bool32 rasterizerDiscardEnable;\r
+ PolygonMode polygonMode;\r
+ CullModeFlags cullMode;\r
+ FrontFace frontFace;\r
+ Bool32 depthBiasEnable;\r
+ float depthBiasConstantFactor;\r
+ float depthBiasClamp;\r
+ float depthBiasSlopeFactor;\r
+ float lineWidth;\r
+ };\r
+ static_assert( sizeof( PipelineRasterizationStateCreateInfo ) == sizeof( VkPipelineRasterizationStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineDepthStencilStateCreateInfo\r
+ {\r
+ PipelineDepthStencilStateCreateInfo( PipelineDepthStencilStateCreateFlags flags_ = PipelineDepthStencilStateCreateFlags(), Bool32 depthTestEnable_ = 0, Bool32 depthWriteEnable_ = 0, CompareOp depthCompareOp_ = CompareOp::eNever, Bool32 depthBoundsTestEnable_ = 0, Bool32 stencilTestEnable_ = 0, StencilOpState front_ = StencilOpState(), StencilOpState back_ = StencilOpState(), float minDepthBounds_ = 0, float maxDepthBounds_ = 0 )\r
+ : flags( flags_ )\r
+ , depthTestEnable( depthTestEnable_ )\r
+ , depthWriteEnable( depthWriteEnable_ )\r
+ , depthCompareOp( depthCompareOp_ )\r
+ , depthBoundsTestEnable( depthBoundsTestEnable_ )\r
+ , stencilTestEnable( stencilTestEnable_ )\r
+ , front( front_ )\r
+ , back( back_ )\r
+ , minDepthBounds( minDepthBounds_ )\r
+ , maxDepthBounds( maxDepthBounds_ )\r
+ {\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo( VkPipelineDepthStencilStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineDepthStencilStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& operator=( VkPipelineDepthStencilStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineDepthStencilStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineDepthStencilStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setFlags( PipelineDepthStencilStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setDepthTestEnable( Bool32 depthTestEnable_ )\r
+ {\r
+ depthTestEnable = depthTestEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setDepthWriteEnable( Bool32 depthWriteEnable_ )\r
+ {\r
+ depthWriteEnable = depthWriteEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setDepthCompareOp( CompareOp depthCompareOp_ )\r
+ {\r
+ depthCompareOp = depthCompareOp_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setDepthBoundsTestEnable( Bool32 depthBoundsTestEnable_ )\r
+ {\r
+ depthBoundsTestEnable = depthBoundsTestEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setStencilTestEnable( Bool32 stencilTestEnable_ )\r
+ {\r
+ stencilTestEnable = stencilTestEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setFront( StencilOpState front_ )\r
+ {\r
+ front = front_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setBack( StencilOpState back_ )\r
+ {\r
+ back = back_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setMinDepthBounds( float minDepthBounds_ )\r
+ {\r
+ minDepthBounds = minDepthBounds_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDepthStencilStateCreateInfo& setMaxDepthBounds( float maxDepthBounds_ )\r
+ {\r
+ maxDepthBounds = maxDepthBounds_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineDepthStencilStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineDepthStencilStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineDepthStencilStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( depthTestEnable == rhs.depthTestEnable )\r
+ && ( depthWriteEnable == rhs.depthWriteEnable )\r
+ && ( depthCompareOp == rhs.depthCompareOp )\r
+ && ( depthBoundsTestEnable == rhs.depthBoundsTestEnable )\r
+ && ( stencilTestEnable == rhs.stencilTestEnable )\r
+ && ( front == rhs.front )\r
+ && ( back == rhs.back )\r
+ && ( minDepthBounds == rhs.minDepthBounds )\r
+ && ( maxDepthBounds == rhs.maxDepthBounds );\r
+ }\r
+\r
+ bool operator!=( PipelineDepthStencilStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineDepthStencilStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineDepthStencilStateCreateFlags flags;\r
+ Bool32 depthTestEnable;\r
+ Bool32 depthWriteEnable;\r
+ CompareOp depthCompareOp;\r
+ Bool32 depthBoundsTestEnable;\r
+ Bool32 stencilTestEnable;\r
+ StencilOpState front;\r
+ StencilOpState back;\r
+ float minDepthBounds;\r
+ float maxDepthBounds;\r
+ };\r
+ static_assert( sizeof( PipelineDepthStencilStateCreateInfo ) == sizeof( VkPipelineDepthStencilStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineCacheCreateInfo\r
+ {\r
+ PipelineCacheCreateInfo( PipelineCacheCreateFlags flags_ = PipelineCacheCreateFlags(), size_t initialDataSize_ = 0, const void* pInitialData_ = nullptr )\r
+ : flags( flags_ )\r
+ , initialDataSize( initialDataSize_ )\r
+ , pInitialData( pInitialData_ )\r
+ {\r
+ }\r
+\r
+ PipelineCacheCreateInfo( VkPipelineCacheCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineCacheCreateInfo ) );\r
+ }\r
+\r
+ PipelineCacheCreateInfo& operator=( VkPipelineCacheCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineCacheCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineCacheCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCacheCreateInfo& setFlags( PipelineCacheCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCacheCreateInfo& setInitialDataSize( size_t initialDataSize_ )\r
+ {\r
+ initialDataSize = initialDataSize_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCacheCreateInfo& setPInitialData( const void* pInitialData_ )\r
+ {\r
+ pInitialData = pInitialData_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineCacheCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineCacheCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineCacheCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( initialDataSize == rhs.initialDataSize )\r
+ && ( pInitialData == rhs.pInitialData );\r
+ }\r
+\r
+ bool operator!=( PipelineCacheCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineCacheCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineCacheCreateFlags flags;\r
+ size_t initialDataSize;\r
+ const void* pInitialData;\r
+ };\r
+ static_assert( sizeof( PipelineCacheCreateInfo ) == sizeof( VkPipelineCacheCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct SamplerCreateInfo\r
+ {\r
+ SamplerCreateInfo( SamplerCreateFlags flags_ = SamplerCreateFlags(), Filter magFilter_ = Filter::eNearest, Filter minFilter_ = Filter::eNearest, SamplerMipmapMode mipmapMode_ = SamplerMipmapMode::eNearest, SamplerAddressMode addressModeU_ = SamplerAddressMode::eRepeat, SamplerAddressMode addressModeV_ = SamplerAddressMode::eRepeat, SamplerAddressMode addressModeW_ = SamplerAddressMode::eRepeat, float mipLodBias_ = 0, Bool32 anisotropyEnable_ = 0, float maxAnisotropy_ = 0, Bool32 compareEnable_ = 0, CompareOp compareOp_ = CompareOp::eNever, float minLod_ = 0, float maxLod_ = 0, BorderColor borderColor_ = BorderColor::eFloatTransparentBlack, Bool32 unnormalizedCoordinates_ = 0 )\r
+ : flags( flags_ )\r
+ , magFilter( magFilter_ )\r
+ , minFilter( minFilter_ )\r
+ , mipmapMode( mipmapMode_ )\r
+ , addressModeU( addressModeU_ )\r
+ , addressModeV( addressModeV_ )\r
+ , addressModeW( addressModeW_ )\r
+ , mipLodBias( mipLodBias_ )\r
+ , anisotropyEnable( anisotropyEnable_ )\r
+ , maxAnisotropy( maxAnisotropy_ )\r
+ , compareEnable( compareEnable_ )\r
+ , compareOp( compareOp_ )\r
+ , minLod( minLod_ )\r
+ , maxLod( maxLod_ )\r
+ , borderColor( borderColor_ )\r
+ , unnormalizedCoordinates( unnormalizedCoordinates_ )\r
+ {\r
+ }\r
+\r
+ SamplerCreateInfo( VkSamplerCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerCreateInfo ) );\r
+ }\r
+\r
+ SamplerCreateInfo& operator=( VkSamplerCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerCreateInfo ) );\r
+ return *this;\r
+ }\r
+ SamplerCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setFlags( SamplerCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMagFilter( Filter magFilter_ )\r
+ {\r
+ magFilter = magFilter_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMinFilter( Filter minFilter_ )\r
+ {\r
+ minFilter = minFilter_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMipmapMode( SamplerMipmapMode mipmapMode_ )\r
+ {\r
+ mipmapMode = mipmapMode_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setAddressModeU( SamplerAddressMode addressModeU_ )\r
+ {\r
+ addressModeU = addressModeU_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setAddressModeV( SamplerAddressMode addressModeV_ )\r
+ {\r
+ addressModeV = addressModeV_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setAddressModeW( SamplerAddressMode addressModeW_ )\r
+ {\r
+ addressModeW = addressModeW_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMipLodBias( float mipLodBias_ )\r
+ {\r
+ mipLodBias = mipLodBias_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setAnisotropyEnable( Bool32 anisotropyEnable_ )\r
+ {\r
+ anisotropyEnable = anisotropyEnable_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMaxAnisotropy( float maxAnisotropy_ )\r
+ {\r
+ maxAnisotropy = maxAnisotropy_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setCompareEnable( Bool32 compareEnable_ )\r
+ {\r
+ compareEnable = compareEnable_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setCompareOp( CompareOp compareOp_ )\r
+ {\r
+ compareOp = compareOp_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMinLod( float minLod_ )\r
+ {\r
+ minLod = minLod_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setMaxLod( float maxLod_ )\r
+ {\r
+ maxLod = maxLod_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setBorderColor( BorderColor borderColor_ )\r
+ {\r
+ borderColor = borderColor_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerCreateInfo& setUnnormalizedCoordinates( Bool32 unnormalizedCoordinates_ )\r
+ {\r
+ unnormalizedCoordinates = unnormalizedCoordinates_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSamplerCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSamplerCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SamplerCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( magFilter == rhs.magFilter )\r
+ && ( minFilter == rhs.minFilter )\r
+ && ( mipmapMode == rhs.mipmapMode )\r
+ && ( addressModeU == rhs.addressModeU )\r
+ && ( addressModeV == rhs.addressModeV )\r
+ && ( addressModeW == rhs.addressModeW )\r
+ && ( mipLodBias == rhs.mipLodBias )\r
+ && ( anisotropyEnable == rhs.anisotropyEnable )\r
+ && ( maxAnisotropy == rhs.maxAnisotropy )\r
+ && ( compareEnable == rhs.compareEnable )\r
+ && ( compareOp == rhs.compareOp )\r
+ && ( minLod == rhs.minLod )\r
+ && ( maxLod == rhs.maxLod )\r
+ && ( borderColor == rhs.borderColor )\r
+ && ( unnormalizedCoordinates == rhs.unnormalizedCoordinates );\r
+ }\r
+\r
+ bool operator!=( SamplerCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSamplerCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SamplerCreateFlags flags;\r
+ Filter magFilter;\r
+ Filter minFilter;\r
+ SamplerMipmapMode mipmapMode;\r
+ SamplerAddressMode addressModeU;\r
+ SamplerAddressMode addressModeV;\r
+ SamplerAddressMode addressModeW;\r
+ float mipLodBias;\r
+ Bool32 anisotropyEnable;\r
+ float maxAnisotropy;\r
+ Bool32 compareEnable;\r
+ CompareOp compareOp;\r
+ float minLod;\r
+ float maxLod;\r
+ BorderColor borderColor;\r
+ Bool32 unnormalizedCoordinates;\r
+ };\r
+ static_assert( sizeof( SamplerCreateInfo ) == sizeof( VkSamplerCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct CommandBufferAllocateInfo\r
+ {\r
+ CommandBufferAllocateInfo( CommandPool commandPool_ = CommandPool(), CommandBufferLevel level_ = CommandBufferLevel::ePrimary, uint32_t commandBufferCount_ = 0 )\r
+ : commandPool( commandPool_ )\r
+ , level( level_ )\r
+ , commandBufferCount( commandBufferCount_ )\r
+ {\r
+ }\r
+\r
+ CommandBufferAllocateInfo( VkCommandBufferAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandBufferAllocateInfo ) );\r
+ }\r
+\r
+ CommandBufferAllocateInfo& operator=( VkCommandBufferAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandBufferAllocateInfo ) );\r
+ return *this;\r
+ }\r
+ CommandBufferAllocateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferAllocateInfo& setCommandPool( CommandPool commandPool_ )\r
+ {\r
+ commandPool = commandPool_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferAllocateInfo& setLevel( CommandBufferLevel level_ )\r
+ {\r
+ level = level_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferAllocateInfo& setCommandBufferCount( uint32_t commandBufferCount_ )\r
+ {\r
+ commandBufferCount = commandBufferCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCommandBufferAllocateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkCommandBufferAllocateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( CommandBufferAllocateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( commandPool == rhs.commandPool )\r
+ && ( level == rhs.level )\r
+ && ( commandBufferCount == rhs.commandBufferCount );\r
+ }\r
+\r
+ bool operator!=( CommandBufferAllocateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCommandBufferAllocateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ CommandPool commandPool;\r
+ CommandBufferLevel level;\r
+ uint32_t commandBufferCount;\r
+ };\r
+ static_assert( sizeof( CommandBufferAllocateInfo ) == sizeof( VkCommandBufferAllocateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct RenderPassBeginInfo\r
+ {\r
+ RenderPassBeginInfo( RenderPass renderPass_ = RenderPass(), Framebuffer framebuffer_ = Framebuffer(), Rect2D renderArea_ = Rect2D(), uint32_t clearValueCount_ = 0, const ClearValue* pClearValues_ = nullptr )\r
+ : renderPass( renderPass_ )\r
+ , framebuffer( framebuffer_ )\r
+ , renderArea( renderArea_ )\r
+ , clearValueCount( clearValueCount_ )\r
+ , pClearValues( pClearValues_ )\r
+ {\r
+ }\r
+\r
+ RenderPassBeginInfo( VkRenderPassBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassBeginInfo ) );\r
+ }\r
+\r
+ RenderPassBeginInfo& operator=( VkRenderPassBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassBeginInfo ) );\r
+ return *this;\r
+ }\r
+ RenderPassBeginInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassBeginInfo& setRenderPass( RenderPass renderPass_ )\r
+ {\r
+ renderPass = renderPass_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassBeginInfo& setFramebuffer( Framebuffer framebuffer_ )\r
+ {\r
+ framebuffer = framebuffer_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassBeginInfo& setRenderArea( Rect2D renderArea_ )\r
+ {\r
+ renderArea = renderArea_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassBeginInfo& setClearValueCount( uint32_t clearValueCount_ )\r
+ {\r
+ clearValueCount = clearValueCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassBeginInfo& setPClearValues( const ClearValue* pClearValues_ )\r
+ {\r
+ pClearValues = pClearValues_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRenderPassBeginInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkRenderPassBeginInfo*>(this);\r
+ }\r
+\r
+ bool operator==( RenderPassBeginInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( renderPass == rhs.renderPass )\r
+ && ( framebuffer == rhs.framebuffer )\r
+ && ( renderArea == rhs.renderArea )\r
+ && ( clearValueCount == rhs.clearValueCount )\r
+ && ( pClearValues == rhs.pClearValues );\r
+ }\r
+\r
+ bool operator!=( RenderPassBeginInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eRenderPassBeginInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ RenderPass renderPass;\r
+ Framebuffer framebuffer;\r
+ Rect2D renderArea;\r
+ uint32_t clearValueCount;\r
+ const ClearValue* pClearValues;\r
+ };\r
+ static_assert( sizeof( RenderPassBeginInfo ) == sizeof( VkRenderPassBeginInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct EventCreateInfo\r
+ {\r
+ EventCreateInfo( EventCreateFlags flags_ = EventCreateFlags() )\r
+ : flags( flags_ )\r
+ {\r
+ }\r
+\r
+ EventCreateInfo( VkEventCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( EventCreateInfo ) );\r
+ }\r
+\r
+ EventCreateInfo& operator=( VkEventCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( EventCreateInfo ) );\r
+ return *this;\r
+ }\r
+ EventCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ EventCreateInfo& setFlags( EventCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkEventCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkEventCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( EventCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( EventCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eEventCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ EventCreateFlags flags;\r
+ };\r
+ static_assert( sizeof( EventCreateInfo ) == sizeof( VkEventCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct SemaphoreCreateInfo\r
+ {\r
+ SemaphoreCreateInfo( SemaphoreCreateFlags flags_ = SemaphoreCreateFlags() )\r
+ : flags( flags_ )\r
+ {\r
+ }\r
+\r
+ SemaphoreCreateInfo( VkSemaphoreCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SemaphoreCreateInfo ) );\r
+ }\r
+\r
+ SemaphoreCreateInfo& operator=( VkSemaphoreCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SemaphoreCreateInfo ) );\r
+ return *this;\r
+ }\r
+ SemaphoreCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SemaphoreCreateInfo& setFlags( SemaphoreCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSemaphoreCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSemaphoreCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SemaphoreCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( SemaphoreCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSemaphoreCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SemaphoreCreateFlags flags;\r
+ };\r
+ static_assert( sizeof( SemaphoreCreateInfo ) == sizeof( VkSemaphoreCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct FramebufferCreateInfo\r
+ {\r
+ FramebufferCreateInfo( FramebufferCreateFlags flags_ = FramebufferCreateFlags(), RenderPass renderPass_ = RenderPass(), uint32_t attachmentCount_ = 0, const ImageView* pAttachments_ = nullptr, uint32_t width_ = 0, uint32_t height_ = 0, uint32_t layers_ = 0 )\r
+ : flags( flags_ )\r
+ , renderPass( renderPass_ )\r
+ , attachmentCount( attachmentCount_ )\r
+ , pAttachments( pAttachments_ )\r
+ , width( width_ )\r
+ , height( height_ )\r
+ , layers( layers_ )\r
+ {\r
+ }\r
+\r
+ FramebufferCreateInfo( VkFramebufferCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FramebufferCreateInfo ) );\r
+ }\r
+\r
+ FramebufferCreateInfo& operator=( VkFramebufferCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FramebufferCreateInfo ) );\r
+ return *this;\r
+ }\r
+ FramebufferCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setFlags( FramebufferCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setRenderPass( RenderPass renderPass_ )\r
+ {\r
+ renderPass = renderPass_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setAttachmentCount( uint32_t attachmentCount_ )\r
+ {\r
+ attachmentCount = attachmentCount_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setPAttachments( const ImageView* pAttachments_ )\r
+ {\r
+ pAttachments = pAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setWidth( uint32_t width_ )\r
+ {\r
+ width = width_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setHeight( uint32_t height_ )\r
+ {\r
+ height = height_;\r
+ return *this;\r
+ }\r
+\r
+ FramebufferCreateInfo& setLayers( uint32_t layers_ )\r
+ {\r
+ layers = layers_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkFramebufferCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkFramebufferCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( FramebufferCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( renderPass == rhs.renderPass )\r
+ && ( attachmentCount == rhs.attachmentCount )\r
+ && ( pAttachments == rhs.pAttachments )\r
+ && ( width == rhs.width )\r
+ && ( height == rhs.height )\r
+ && ( layers == rhs.layers );\r
+ }\r
+\r
+ bool operator!=( FramebufferCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eFramebufferCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ FramebufferCreateFlags flags;\r
+ RenderPass renderPass;\r
+ uint32_t attachmentCount;\r
+ const ImageView* pAttachments;\r
+ uint32_t width;\r
+ uint32_t height;\r
+ uint32_t layers;\r
+ };\r
+ static_assert( sizeof( FramebufferCreateInfo ) == sizeof( VkFramebufferCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct DisplayModeCreateInfoKHR\r
+ {\r
+ DisplayModeCreateInfoKHR( DisplayModeCreateFlagsKHR flags_ = DisplayModeCreateFlagsKHR(), DisplayModeParametersKHR parameters_ = DisplayModeParametersKHR() )\r
+ : flags( flags_ )\r
+ , parameters( parameters_ )\r
+ {\r
+ }\r
+\r
+ DisplayModeCreateInfoKHR( VkDisplayModeCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayModeCreateInfoKHR ) );\r
+ }\r
+\r
+ DisplayModeCreateInfoKHR& operator=( VkDisplayModeCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayModeCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ DisplayModeCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayModeCreateInfoKHR& setFlags( DisplayModeCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayModeCreateInfoKHR& setParameters( DisplayModeParametersKHR parameters_ )\r
+ {\r
+ parameters = parameters_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDisplayModeCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayModeCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayModeCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( parameters == rhs.parameters );\r
+ }\r
+\r
+ bool operator!=( DisplayModeCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDisplayModeCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DisplayModeCreateFlagsKHR flags;\r
+ DisplayModeParametersKHR parameters;\r
+ };\r
+ static_assert( sizeof( DisplayModeCreateInfoKHR ) == sizeof( VkDisplayModeCreateInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct DisplayPresentInfoKHR\r
+ {\r
+ DisplayPresentInfoKHR( Rect2D srcRect_ = Rect2D(), Rect2D dstRect_ = Rect2D(), Bool32 persistent_ = 0 )\r
+ : srcRect( srcRect_ )\r
+ , dstRect( dstRect_ )\r
+ , persistent( persistent_ )\r
+ {\r
+ }\r
+\r
+ DisplayPresentInfoKHR( VkDisplayPresentInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayPresentInfoKHR ) );\r
+ }\r
+\r
+ DisplayPresentInfoKHR& operator=( VkDisplayPresentInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayPresentInfoKHR ) );\r
+ return *this;\r
+ }\r
+ DisplayPresentInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayPresentInfoKHR& setSrcRect( Rect2D srcRect_ )\r
+ {\r
+ srcRect = srcRect_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayPresentInfoKHR& setDstRect( Rect2D dstRect_ )\r
+ {\r
+ dstRect = dstRect_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayPresentInfoKHR& setPersistent( Bool32 persistent_ )\r
+ {\r
+ persistent = persistent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDisplayPresentInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayPresentInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayPresentInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( srcRect == rhs.srcRect )\r
+ && ( dstRect == rhs.dstRect )\r
+ && ( persistent == rhs.persistent );\r
+ }\r
+\r
+ bool operator!=( DisplayPresentInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDisplayPresentInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Rect2D srcRect;\r
+ Rect2D dstRect;\r
+ Bool32 persistent;\r
+ };\r
+ static_assert( sizeof( DisplayPresentInfoKHR ) == sizeof( VkDisplayPresentInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ struct AndroidSurfaceCreateInfoKHR\r
+ {\r
+ AndroidSurfaceCreateInfoKHR( AndroidSurfaceCreateFlagsKHR flags_ = AndroidSurfaceCreateFlagsKHR(), struct ANativeWindow* window_ = nullptr )\r
+ : flags( flags_ )\r
+ , window( window_ )\r
+ {\r
+ }\r
+\r
+ AndroidSurfaceCreateInfoKHR( VkAndroidSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AndroidSurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ AndroidSurfaceCreateInfoKHR& operator=( VkAndroidSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AndroidSurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ AndroidSurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ AndroidSurfaceCreateInfoKHR& setFlags( AndroidSurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ AndroidSurfaceCreateInfoKHR& setWindow( struct ANativeWindow* window_ )\r
+ {\r
+ window = window_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkAndroidSurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkAndroidSurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( AndroidSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( window == rhs.window );\r
+ }\r
+\r
+ bool operator!=( AndroidSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eAndroidSurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ AndroidSurfaceCreateFlagsKHR flags;\r
+ struct ANativeWindow* window;\r
+ };\r
+ static_assert( sizeof( AndroidSurfaceCreateInfoKHR ) == sizeof( VkAndroidSurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ struct MirSurfaceCreateInfoKHR\r
+ {\r
+ MirSurfaceCreateInfoKHR( MirSurfaceCreateFlagsKHR flags_ = MirSurfaceCreateFlagsKHR(), MirConnection* connection_ = nullptr, MirSurface* mirSurface_ = nullptr )\r
+ : flags( flags_ )\r
+ , connection( connection_ )\r
+ , mirSurface( mirSurface_ )\r
+ {\r
+ }\r
+\r
+ MirSurfaceCreateInfoKHR( VkMirSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MirSurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ MirSurfaceCreateInfoKHR& operator=( VkMirSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MirSurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ MirSurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MirSurfaceCreateInfoKHR& setFlags( MirSurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ MirSurfaceCreateInfoKHR& setConnection( MirConnection* connection_ )\r
+ {\r
+ connection = connection_;\r
+ return *this;\r
+ }\r
+\r
+ MirSurfaceCreateInfoKHR& setMirSurface( MirSurface* mirSurface_ )\r
+ {\r
+ mirSurface = mirSurface_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMirSurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkMirSurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( MirSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( connection == rhs.connection )\r
+ && ( mirSurface == rhs.mirSurface );\r
+ }\r
+\r
+ bool operator!=( MirSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMirSurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ MirSurfaceCreateFlagsKHR flags;\r
+ MirConnection* connection;\r
+ MirSurface* mirSurface;\r
+ };\r
+ static_assert( sizeof( MirSurfaceCreateInfoKHR ) == sizeof( VkMirSurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ struct ViSurfaceCreateInfoNN\r
+ {\r
+ ViSurfaceCreateInfoNN( ViSurfaceCreateFlagsNN flags_ = ViSurfaceCreateFlagsNN(), void* window_ = nullptr )\r
+ : flags( flags_ )\r
+ , window( window_ )\r
+ {\r
+ }\r
+\r
+ ViSurfaceCreateInfoNN( VkViSurfaceCreateInfoNN const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ViSurfaceCreateInfoNN ) );\r
+ }\r
+\r
+ ViSurfaceCreateInfoNN& operator=( VkViSurfaceCreateInfoNN const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ViSurfaceCreateInfoNN ) );\r
+ return *this;\r
+ }\r
+ ViSurfaceCreateInfoNN& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ViSurfaceCreateInfoNN& setFlags( ViSurfaceCreateFlagsNN flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ViSurfaceCreateInfoNN& setWindow( void* window_ )\r
+ {\r
+ window = window_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkViSurfaceCreateInfoNN&() const\r
+ {\r
+ return *reinterpret_cast<const VkViSurfaceCreateInfoNN*>(this);\r
+ }\r
+\r
+ bool operator==( ViSurfaceCreateInfoNN const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( window == rhs.window );\r
+ }\r
+\r
+ bool operator!=( ViSurfaceCreateInfoNN const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eViSurfaceCreateInfoNN;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ViSurfaceCreateFlagsNN flags;\r
+ void* window;\r
+ };\r
+ static_assert( sizeof( ViSurfaceCreateInfoNN ) == sizeof( VkViSurfaceCreateInfoNN ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ struct WaylandSurfaceCreateInfoKHR\r
+ {\r
+ WaylandSurfaceCreateInfoKHR( WaylandSurfaceCreateFlagsKHR flags_ = WaylandSurfaceCreateFlagsKHR(), struct wl_display* display_ = nullptr, struct wl_surface* surface_ = nullptr )\r
+ : flags( flags_ )\r
+ , display( display_ )\r
+ , surface( surface_ )\r
+ {\r
+ }\r
+\r
+ WaylandSurfaceCreateInfoKHR( VkWaylandSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( WaylandSurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ WaylandSurfaceCreateInfoKHR& operator=( VkWaylandSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( WaylandSurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ WaylandSurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ WaylandSurfaceCreateInfoKHR& setFlags( WaylandSurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ WaylandSurfaceCreateInfoKHR& setDisplay( struct wl_display* display_ )\r
+ {\r
+ display = display_;\r
+ return *this;\r
+ }\r
+\r
+ WaylandSurfaceCreateInfoKHR& setSurface( struct wl_surface* surface_ )\r
+ {\r
+ surface = surface_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkWaylandSurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkWaylandSurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( WaylandSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( display == rhs.display )\r
+ && ( surface == rhs.surface );\r
+ }\r
+\r
+ bool operator!=( WaylandSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eWaylandSurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ WaylandSurfaceCreateFlagsKHR flags;\r
+ struct wl_display* display;\r
+ struct wl_surface* surface;\r
+ };\r
+ static_assert( sizeof( WaylandSurfaceCreateInfoKHR ) == sizeof( VkWaylandSurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct Win32SurfaceCreateInfoKHR\r
+ {\r
+ Win32SurfaceCreateInfoKHR( Win32SurfaceCreateFlagsKHR flags_ = Win32SurfaceCreateFlagsKHR(), HINSTANCE hinstance_ = 0, HWND hwnd_ = 0 )\r
+ : flags( flags_ )\r
+ , hinstance( hinstance_ )\r
+ , hwnd( hwnd_ )\r
+ {\r
+ }\r
+\r
+ Win32SurfaceCreateInfoKHR( VkWin32SurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Win32SurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ Win32SurfaceCreateInfoKHR& operator=( VkWin32SurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Win32SurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ Win32SurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ Win32SurfaceCreateInfoKHR& setFlags( Win32SurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ Win32SurfaceCreateInfoKHR& setHinstance( HINSTANCE hinstance_ )\r
+ {\r
+ hinstance = hinstance_;\r
+ return *this;\r
+ }\r
+\r
+ Win32SurfaceCreateInfoKHR& setHwnd( HWND hwnd_ )\r
+ {\r
+ hwnd = hwnd_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkWin32SurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkWin32SurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( Win32SurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( hinstance == rhs.hinstance )\r
+ && ( hwnd == rhs.hwnd );\r
+ }\r
+\r
+ bool operator!=( Win32SurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eWin32SurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Win32SurfaceCreateFlagsKHR flags;\r
+ HINSTANCE hinstance;\r
+ HWND hwnd;\r
+ };\r
+ static_assert( sizeof( Win32SurfaceCreateInfoKHR ) == sizeof( VkWin32SurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ struct XlibSurfaceCreateInfoKHR\r
+ {\r
+ XlibSurfaceCreateInfoKHR( XlibSurfaceCreateFlagsKHR flags_ = XlibSurfaceCreateFlagsKHR(), Display* dpy_ = nullptr, Window window_ = 0 )\r
+ : flags( flags_ )\r
+ , dpy( dpy_ )\r
+ , window( window_ )\r
+ {\r
+ }\r
+\r
+ XlibSurfaceCreateInfoKHR( VkXlibSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( XlibSurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ XlibSurfaceCreateInfoKHR& operator=( VkXlibSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( XlibSurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ XlibSurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ XlibSurfaceCreateInfoKHR& setFlags( XlibSurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ XlibSurfaceCreateInfoKHR& setDpy( Display* dpy_ )\r
+ {\r
+ dpy = dpy_;\r
+ return *this;\r
+ }\r
+\r
+ XlibSurfaceCreateInfoKHR& setWindow( Window window_ )\r
+ {\r
+ window = window_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkXlibSurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkXlibSurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( XlibSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( dpy == rhs.dpy )\r
+ && ( window == rhs.window );\r
+ }\r
+\r
+ bool operator!=( XlibSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eXlibSurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ XlibSurfaceCreateFlagsKHR flags;\r
+ Display* dpy;\r
+ Window window;\r
+ };\r
+ static_assert( sizeof( XlibSurfaceCreateInfoKHR ) == sizeof( VkXlibSurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ struct XcbSurfaceCreateInfoKHR\r
+ {\r
+ XcbSurfaceCreateInfoKHR( XcbSurfaceCreateFlagsKHR flags_ = XcbSurfaceCreateFlagsKHR(), xcb_connection_t* connection_ = nullptr, xcb_window_t window_ = 0 )\r
+ : flags( flags_ )\r
+ , connection( connection_ )\r
+ , window( window_ )\r
+ {\r
+ }\r
+\r
+ XcbSurfaceCreateInfoKHR( VkXcbSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( XcbSurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ XcbSurfaceCreateInfoKHR& operator=( VkXcbSurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( XcbSurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ XcbSurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ XcbSurfaceCreateInfoKHR& setFlags( XcbSurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ XcbSurfaceCreateInfoKHR& setConnection( xcb_connection_t* connection_ )\r
+ {\r
+ connection = connection_;\r
+ return *this;\r
+ }\r
+\r
+ XcbSurfaceCreateInfoKHR& setWindow( xcb_window_t window_ )\r
+ {\r
+ window = window_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkXcbSurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkXcbSurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( XcbSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( connection == rhs.connection )\r
+ && ( window == rhs.window );\r
+ }\r
+\r
+ bool operator!=( XcbSurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eXcbSurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ XcbSurfaceCreateFlagsKHR flags;\r
+ xcb_connection_t* connection;\r
+ xcb_window_t window;\r
+ };\r
+ static_assert( sizeof( XcbSurfaceCreateInfoKHR ) == sizeof( VkXcbSurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+ struct DebugMarkerMarkerInfoEXT\r
+ {\r
+ DebugMarkerMarkerInfoEXT( const char* pMarkerName_ = nullptr, std::array<float,4> const& color_ = { { 0, 0, 0, 0 } } )\r
+ : pMarkerName( pMarkerName_ )\r
+ {\r
+ memcpy( &color, color_.data(), 4 * sizeof( float ) );\r
+ }\r
+\r
+ DebugMarkerMarkerInfoEXT( VkDebugMarkerMarkerInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugMarkerMarkerInfoEXT ) );\r
+ }\r
+\r
+ DebugMarkerMarkerInfoEXT& operator=( VkDebugMarkerMarkerInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugMarkerMarkerInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugMarkerMarkerInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerMarkerInfoEXT& setPMarkerName( const char* pMarkerName_ )\r
+ {\r
+ pMarkerName = pMarkerName_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerMarkerInfoEXT& setColor( std::array<float,4> color_ )\r
+ {\r
+ memcpy( &color, color_.data(), 4 * sizeof( float ) );\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugMarkerMarkerInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugMarkerMarkerInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugMarkerMarkerInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pMarkerName == rhs.pMarkerName )\r
+ && ( memcmp( color, rhs.color, 4 * sizeof( float ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( DebugMarkerMarkerInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugMarkerMarkerInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const char* pMarkerName;\r
+ float color[4];\r
+ };\r
+ static_assert( sizeof( DebugMarkerMarkerInfoEXT ) == sizeof( VkDebugMarkerMarkerInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct DedicatedAllocationImageCreateInfoNV\r
+ {\r
+ DedicatedAllocationImageCreateInfoNV( Bool32 dedicatedAllocation_ = 0 )\r
+ : dedicatedAllocation( dedicatedAllocation_ )\r
+ {\r
+ }\r
+\r
+ DedicatedAllocationImageCreateInfoNV( VkDedicatedAllocationImageCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DedicatedAllocationImageCreateInfoNV ) );\r
+ }\r
+\r
+ DedicatedAllocationImageCreateInfoNV& operator=( VkDedicatedAllocationImageCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DedicatedAllocationImageCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ DedicatedAllocationImageCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DedicatedAllocationImageCreateInfoNV& setDedicatedAllocation( Bool32 dedicatedAllocation_ )\r
+ {\r
+ dedicatedAllocation = dedicatedAllocation_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDedicatedAllocationImageCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkDedicatedAllocationImageCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( DedicatedAllocationImageCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( dedicatedAllocation == rhs.dedicatedAllocation );\r
+ }\r
+\r
+ bool operator!=( DedicatedAllocationImageCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDedicatedAllocationImageCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 dedicatedAllocation;\r
+ };\r
+ static_assert( sizeof( DedicatedAllocationImageCreateInfoNV ) == sizeof( VkDedicatedAllocationImageCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ struct DedicatedAllocationBufferCreateInfoNV\r
+ {\r
+ DedicatedAllocationBufferCreateInfoNV( Bool32 dedicatedAllocation_ = 0 )\r
+ : dedicatedAllocation( dedicatedAllocation_ )\r
+ {\r
+ }\r
+\r
+ DedicatedAllocationBufferCreateInfoNV( VkDedicatedAllocationBufferCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DedicatedAllocationBufferCreateInfoNV ) );\r
+ }\r
+\r
+ DedicatedAllocationBufferCreateInfoNV& operator=( VkDedicatedAllocationBufferCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DedicatedAllocationBufferCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ DedicatedAllocationBufferCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DedicatedAllocationBufferCreateInfoNV& setDedicatedAllocation( Bool32 dedicatedAllocation_ )\r
+ {\r
+ dedicatedAllocation = dedicatedAllocation_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDedicatedAllocationBufferCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkDedicatedAllocationBufferCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( DedicatedAllocationBufferCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( dedicatedAllocation == rhs.dedicatedAllocation );\r
+ }\r
+\r
+ bool operator!=( DedicatedAllocationBufferCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDedicatedAllocationBufferCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 dedicatedAllocation;\r
+ };\r
+ static_assert( sizeof( DedicatedAllocationBufferCreateInfoNV ) == sizeof( VkDedicatedAllocationBufferCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ struct DedicatedAllocationMemoryAllocateInfoNV\r
+ {\r
+ DedicatedAllocationMemoryAllocateInfoNV( Image image_ = Image(), Buffer buffer_ = Buffer() )\r
+ : image( image_ )\r
+ , buffer( buffer_ )\r
+ {\r
+ }\r
+\r
+ DedicatedAllocationMemoryAllocateInfoNV( VkDedicatedAllocationMemoryAllocateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DedicatedAllocationMemoryAllocateInfoNV ) );\r
+ }\r
+\r
+ DedicatedAllocationMemoryAllocateInfoNV& operator=( VkDedicatedAllocationMemoryAllocateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DedicatedAllocationMemoryAllocateInfoNV ) );\r
+ return *this;\r
+ }\r
+ DedicatedAllocationMemoryAllocateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DedicatedAllocationMemoryAllocateInfoNV& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ DedicatedAllocationMemoryAllocateInfoNV& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDedicatedAllocationMemoryAllocateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkDedicatedAllocationMemoryAllocateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( DedicatedAllocationMemoryAllocateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( image == rhs.image )\r
+ && ( buffer == rhs.buffer );\r
+ }\r
+\r
+ bool operator!=( DedicatedAllocationMemoryAllocateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDedicatedAllocationMemoryAllocateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Image image;\r
+ Buffer buffer;\r
+ };\r
+ static_assert( sizeof( DedicatedAllocationMemoryAllocateInfoNV ) == sizeof( VkDedicatedAllocationMemoryAllocateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ struct ExportMemoryWin32HandleInfoNV\r
+ {\r
+ ExportMemoryWin32HandleInfoNV( const SECURITY_ATTRIBUTES* pAttributes_ = nullptr, DWORD dwAccess_ = 0 )\r
+ : pAttributes( pAttributes_ )\r
+ , dwAccess( dwAccess_ )\r
+ {\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoNV( VkExportMemoryWin32HandleInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryWin32HandleInfoNV ) );\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoNV& operator=( VkExportMemoryWin32HandleInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryWin32HandleInfoNV ) );\r
+ return *this;\r
+ }\r
+ ExportMemoryWin32HandleInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoNV& setPAttributes( const SECURITY_ATTRIBUTES* pAttributes_ )\r
+ {\r
+ pAttributes = pAttributes_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoNV& setDwAccess( DWORD dwAccess_ )\r
+ {\r
+ dwAccess = dwAccess_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportMemoryWin32HandleInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportMemoryWin32HandleInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( ExportMemoryWin32HandleInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pAttributes == rhs.pAttributes )\r
+ && ( dwAccess == rhs.dwAccess );\r
+ }\r
+\r
+ bool operator!=( ExportMemoryWin32HandleInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportMemoryWin32HandleInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const SECURITY_ATTRIBUTES* pAttributes;\r
+ DWORD dwAccess;\r
+ };\r
+ static_assert( sizeof( ExportMemoryWin32HandleInfoNV ) == sizeof( VkExportMemoryWin32HandleInfoNV ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ struct Win32KeyedMutexAcquireReleaseInfoNV\r
+ {\r
+ Win32KeyedMutexAcquireReleaseInfoNV( uint32_t acquireCount_ = 0, const DeviceMemory* pAcquireSyncs_ = nullptr, const uint64_t* pAcquireKeys_ = nullptr, const uint32_t* pAcquireTimeoutMilliseconds_ = nullptr, uint32_t releaseCount_ = 0, const DeviceMemory* pReleaseSyncs_ = nullptr, const uint64_t* pReleaseKeys_ = nullptr )\r
+ : acquireCount( acquireCount_ )\r
+ , pAcquireSyncs( pAcquireSyncs_ )\r
+ , pAcquireKeys( pAcquireKeys_ )\r
+ , pAcquireTimeoutMilliseconds( pAcquireTimeoutMilliseconds_ )\r
+ , releaseCount( releaseCount_ )\r
+ , pReleaseSyncs( pReleaseSyncs_ )\r
+ , pReleaseKeys( pReleaseKeys_ )\r
+ {\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV( VkWin32KeyedMutexAcquireReleaseInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Win32KeyedMutexAcquireReleaseInfoNV ) );\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& operator=( VkWin32KeyedMutexAcquireReleaseInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Win32KeyedMutexAcquireReleaseInfoNV ) );\r
+ return *this;\r
+ }\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setAcquireCount( uint32_t acquireCount_ )\r
+ {\r
+ acquireCount = acquireCount_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setPAcquireSyncs( const DeviceMemory* pAcquireSyncs_ )\r
+ {\r
+ pAcquireSyncs = pAcquireSyncs_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setPAcquireKeys( const uint64_t* pAcquireKeys_ )\r
+ {\r
+ pAcquireKeys = pAcquireKeys_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setPAcquireTimeoutMilliseconds( const uint32_t* pAcquireTimeoutMilliseconds_ )\r
+ {\r
+ pAcquireTimeoutMilliseconds = pAcquireTimeoutMilliseconds_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setReleaseCount( uint32_t releaseCount_ )\r
+ {\r
+ releaseCount = releaseCount_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setPReleaseSyncs( const DeviceMemory* pReleaseSyncs_ )\r
+ {\r
+ pReleaseSyncs = pReleaseSyncs_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoNV& setPReleaseKeys( const uint64_t* pReleaseKeys_ )\r
+ {\r
+ pReleaseKeys = pReleaseKeys_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkWin32KeyedMutexAcquireReleaseInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkWin32KeyedMutexAcquireReleaseInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( Win32KeyedMutexAcquireReleaseInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( acquireCount == rhs.acquireCount )\r
+ && ( pAcquireSyncs == rhs.pAcquireSyncs )\r
+ && ( pAcquireKeys == rhs.pAcquireKeys )\r
+ && ( pAcquireTimeoutMilliseconds == rhs.pAcquireTimeoutMilliseconds )\r
+ && ( releaseCount == rhs.releaseCount )\r
+ && ( pReleaseSyncs == rhs.pReleaseSyncs )\r
+ && ( pReleaseKeys == rhs.pReleaseKeys );\r
+ }\r
+\r
+ bool operator!=( Win32KeyedMutexAcquireReleaseInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eWin32KeyedMutexAcquireReleaseInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t acquireCount;\r
+ const DeviceMemory* pAcquireSyncs;\r
+ const uint64_t* pAcquireKeys;\r
+ const uint32_t* pAcquireTimeoutMilliseconds;\r
+ uint32_t releaseCount;\r
+ const DeviceMemory* pReleaseSyncs;\r
+ const uint64_t* pReleaseKeys;\r
+ };\r
+ static_assert( sizeof( Win32KeyedMutexAcquireReleaseInfoNV ) == sizeof( VkWin32KeyedMutexAcquireReleaseInfoNV ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+\r
+ struct DeviceGeneratedCommandsFeaturesNVX\r
+ {\r
+ DeviceGeneratedCommandsFeaturesNVX( Bool32 computeBindingPointSupport_ = 0 )\r
+ : computeBindingPointSupport( computeBindingPointSupport_ )\r
+ {\r
+ }\r
+\r
+ DeviceGeneratedCommandsFeaturesNVX( VkDeviceGeneratedCommandsFeaturesNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGeneratedCommandsFeaturesNVX ) );\r
+ }\r
+\r
+ DeviceGeneratedCommandsFeaturesNVX& operator=( VkDeviceGeneratedCommandsFeaturesNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGeneratedCommandsFeaturesNVX ) );\r
+ return *this;\r
+ }\r
+ DeviceGeneratedCommandsFeaturesNVX& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGeneratedCommandsFeaturesNVX& setComputeBindingPointSupport( Bool32 computeBindingPointSupport_ )\r
+ {\r
+ computeBindingPointSupport = computeBindingPointSupport_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGeneratedCommandsFeaturesNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGeneratedCommandsFeaturesNVX*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGeneratedCommandsFeaturesNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( computeBindingPointSupport == rhs.computeBindingPointSupport );\r
+ }\r
+\r
+ bool operator!=( DeviceGeneratedCommandsFeaturesNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGeneratedCommandsFeaturesNVX;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 computeBindingPointSupport;\r
+ };\r
+ static_assert( sizeof( DeviceGeneratedCommandsFeaturesNVX ) == sizeof( VkDeviceGeneratedCommandsFeaturesNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct DeviceGeneratedCommandsLimitsNVX\r
+ {\r
+ DeviceGeneratedCommandsLimitsNVX( uint32_t maxIndirectCommandsLayoutTokenCount_ = 0, uint32_t maxObjectEntryCounts_ = 0, uint32_t minSequenceCountBufferOffsetAlignment_ = 0, uint32_t minSequenceIndexBufferOffsetAlignment_ = 0, uint32_t minCommandsTokenBufferOffsetAlignment_ = 0 )\r
+ : maxIndirectCommandsLayoutTokenCount( maxIndirectCommandsLayoutTokenCount_ )\r
+ , maxObjectEntryCounts( maxObjectEntryCounts_ )\r
+ , minSequenceCountBufferOffsetAlignment( minSequenceCountBufferOffsetAlignment_ )\r
+ , minSequenceIndexBufferOffsetAlignment( minSequenceIndexBufferOffsetAlignment_ )\r
+ , minCommandsTokenBufferOffsetAlignment( minCommandsTokenBufferOffsetAlignment_ )\r
+ {\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX( VkDeviceGeneratedCommandsLimitsNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGeneratedCommandsLimitsNVX ) );\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX& operator=( VkDeviceGeneratedCommandsLimitsNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGeneratedCommandsLimitsNVX ) );\r
+ return *this;\r
+ }\r
+ DeviceGeneratedCommandsLimitsNVX& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX& setMaxIndirectCommandsLayoutTokenCount( uint32_t maxIndirectCommandsLayoutTokenCount_ )\r
+ {\r
+ maxIndirectCommandsLayoutTokenCount = maxIndirectCommandsLayoutTokenCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX& setMaxObjectEntryCounts( uint32_t maxObjectEntryCounts_ )\r
+ {\r
+ maxObjectEntryCounts = maxObjectEntryCounts_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX& setMinSequenceCountBufferOffsetAlignment( uint32_t minSequenceCountBufferOffsetAlignment_ )\r
+ {\r
+ minSequenceCountBufferOffsetAlignment = minSequenceCountBufferOffsetAlignment_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX& setMinSequenceIndexBufferOffsetAlignment( uint32_t minSequenceIndexBufferOffsetAlignment_ )\r
+ {\r
+ minSequenceIndexBufferOffsetAlignment = minSequenceIndexBufferOffsetAlignment_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGeneratedCommandsLimitsNVX& setMinCommandsTokenBufferOffsetAlignment( uint32_t minCommandsTokenBufferOffsetAlignment_ )\r
+ {\r
+ minCommandsTokenBufferOffsetAlignment = minCommandsTokenBufferOffsetAlignment_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGeneratedCommandsLimitsNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGeneratedCommandsLimitsNVX*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGeneratedCommandsLimitsNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxIndirectCommandsLayoutTokenCount == rhs.maxIndirectCommandsLayoutTokenCount )\r
+ && ( maxObjectEntryCounts == rhs.maxObjectEntryCounts )\r
+ && ( minSequenceCountBufferOffsetAlignment == rhs.minSequenceCountBufferOffsetAlignment )\r
+ && ( minSequenceIndexBufferOffsetAlignment == rhs.minSequenceIndexBufferOffsetAlignment )\r
+ && ( minCommandsTokenBufferOffsetAlignment == rhs.minCommandsTokenBufferOffsetAlignment );\r
+ }\r
+\r
+ bool operator!=( DeviceGeneratedCommandsLimitsNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGeneratedCommandsLimitsNVX;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t maxIndirectCommandsLayoutTokenCount;\r
+ uint32_t maxObjectEntryCounts;\r
+ uint32_t minSequenceCountBufferOffsetAlignment;\r
+ uint32_t minSequenceIndexBufferOffsetAlignment;\r
+ uint32_t minCommandsTokenBufferOffsetAlignment;\r
+ };\r
+ static_assert( sizeof( DeviceGeneratedCommandsLimitsNVX ) == sizeof( VkDeviceGeneratedCommandsLimitsNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct CmdReserveSpaceForCommandsInfoNVX\r
+ {\r
+ CmdReserveSpaceForCommandsInfoNVX( ObjectTableNVX objectTable_ = ObjectTableNVX(), IndirectCommandsLayoutNVX indirectCommandsLayout_ = IndirectCommandsLayoutNVX(), uint32_t maxSequencesCount_ = 0 )\r
+ : objectTable( objectTable_ )\r
+ , indirectCommandsLayout( indirectCommandsLayout_ )\r
+ , maxSequencesCount( maxSequencesCount_ )\r
+ {\r
+ }\r
+\r
+ CmdReserveSpaceForCommandsInfoNVX( VkCmdReserveSpaceForCommandsInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CmdReserveSpaceForCommandsInfoNVX ) );\r
+ }\r
+\r
+ CmdReserveSpaceForCommandsInfoNVX& operator=( VkCmdReserveSpaceForCommandsInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CmdReserveSpaceForCommandsInfoNVX ) );\r
+ return *this;\r
+ }\r
+ CmdReserveSpaceForCommandsInfoNVX& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CmdReserveSpaceForCommandsInfoNVX& setObjectTable( ObjectTableNVX objectTable_ )\r
+ {\r
+ objectTable = objectTable_;\r
+ return *this;\r
+ }\r
+\r
+ CmdReserveSpaceForCommandsInfoNVX& setIndirectCommandsLayout( IndirectCommandsLayoutNVX indirectCommandsLayout_ )\r
+ {\r
+ indirectCommandsLayout = indirectCommandsLayout_;\r
+ return *this;\r
+ }\r
+\r
+ CmdReserveSpaceForCommandsInfoNVX& setMaxSequencesCount( uint32_t maxSequencesCount_ )\r
+ {\r
+ maxSequencesCount = maxSequencesCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCmdReserveSpaceForCommandsInfoNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkCmdReserveSpaceForCommandsInfoNVX*>(this);\r
+ }\r
+\r
+ bool operator==( CmdReserveSpaceForCommandsInfoNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectTable == rhs.objectTable )\r
+ && ( indirectCommandsLayout == rhs.indirectCommandsLayout )\r
+ && ( maxSequencesCount == rhs.maxSequencesCount );\r
+ }\r
+\r
+ bool operator!=( CmdReserveSpaceForCommandsInfoNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCmdReserveSpaceForCommandsInfoNVX;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ObjectTableNVX objectTable;\r
+ IndirectCommandsLayoutNVX indirectCommandsLayout;\r
+ uint32_t maxSequencesCount;\r
+ };\r
+ static_assert( sizeof( CmdReserveSpaceForCommandsInfoNVX ) == sizeof( VkCmdReserveSpaceForCommandsInfoNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceFeatures2\r
+ {\r
+ PhysicalDeviceFeatures2( PhysicalDeviceFeatures features_ = PhysicalDeviceFeatures() )\r
+ : features( features_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceFeatures2( VkPhysicalDeviceFeatures2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceFeatures2 ) );\r
+ }\r
+\r
+ PhysicalDeviceFeatures2& operator=( VkPhysicalDeviceFeatures2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceFeatures2 ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceFeatures2& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceFeatures2& setFeatures( PhysicalDeviceFeatures features_ )\r
+ {\r
+ features = features_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceFeatures2&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceFeatures2*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceFeatures2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( features == rhs.features );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceFeatures2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceFeatures2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ PhysicalDeviceFeatures features;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceFeatures2 ) == sizeof( VkPhysicalDeviceFeatures2 ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceFeatures2KHR = PhysicalDeviceFeatures2;\r
+\r
+ struct PhysicalDevicePushDescriptorPropertiesKHR\r
+ {\r
+ PhysicalDevicePushDescriptorPropertiesKHR( uint32_t maxPushDescriptors_ = 0 )\r
+ : maxPushDescriptors( maxPushDescriptors_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDevicePushDescriptorPropertiesKHR( VkPhysicalDevicePushDescriptorPropertiesKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDevicePushDescriptorPropertiesKHR ) );\r
+ }\r
+\r
+ PhysicalDevicePushDescriptorPropertiesKHR& operator=( VkPhysicalDevicePushDescriptorPropertiesKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDevicePushDescriptorPropertiesKHR ) );\r
+ return *this;\r
+ }\r
+ PhysicalDevicePushDescriptorPropertiesKHR& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDevicePushDescriptorPropertiesKHR& setMaxPushDescriptors( uint32_t maxPushDescriptors_ )\r
+ {\r
+ maxPushDescriptors = maxPushDescriptors_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDevicePushDescriptorPropertiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDevicePushDescriptorPropertiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDevicePushDescriptorPropertiesKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxPushDescriptors == rhs.maxPushDescriptors );\r
+ }\r
+\r
+ bool operator!=( PhysicalDevicePushDescriptorPropertiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDevicePushDescriptorPropertiesKHR;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxPushDescriptors;\r
+ };\r
+ static_assert( sizeof( PhysicalDevicePushDescriptorPropertiesKHR ) == sizeof( VkPhysicalDevicePushDescriptorPropertiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct PresentRegionsKHR\r
+ {\r
+ PresentRegionsKHR( uint32_t swapchainCount_ = 0, const PresentRegionKHR* pRegions_ = nullptr )\r
+ : swapchainCount( swapchainCount_ )\r
+ , pRegions( pRegions_ )\r
+ {\r
+ }\r
+\r
+ PresentRegionsKHR( VkPresentRegionsKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentRegionsKHR ) );\r
+ }\r
+\r
+ PresentRegionsKHR& operator=( VkPresentRegionsKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentRegionsKHR ) );\r
+ return *this;\r
+ }\r
+ PresentRegionsKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PresentRegionsKHR& setSwapchainCount( uint32_t swapchainCount_ )\r
+ {\r
+ swapchainCount = swapchainCount_;\r
+ return *this;\r
+ }\r
+\r
+ PresentRegionsKHR& setPRegions( const PresentRegionKHR* pRegions_ )\r
+ {\r
+ pRegions = pRegions_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPresentRegionsKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkPresentRegionsKHR*>(this);\r
+ }\r
+\r
+ bool operator==( PresentRegionsKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( swapchainCount == rhs.swapchainCount )\r
+ && ( pRegions == rhs.pRegions );\r
+ }\r
+\r
+ bool operator!=( PresentRegionsKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePresentRegionsKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t swapchainCount;\r
+ const PresentRegionKHR* pRegions;\r
+ };\r
+ static_assert( sizeof( PresentRegionsKHR ) == sizeof( VkPresentRegionsKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceVariablePointerFeatures\r
+ {\r
+ PhysicalDeviceVariablePointerFeatures( Bool32 variablePointersStorageBuffer_ = 0, Bool32 variablePointers_ = 0 )\r
+ : variablePointersStorageBuffer( variablePointersStorageBuffer_ )\r
+ , variablePointers( variablePointers_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceVariablePointerFeatures( VkPhysicalDeviceVariablePointerFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceVariablePointerFeatures ) );\r
+ }\r
+\r
+ PhysicalDeviceVariablePointerFeatures& operator=( VkPhysicalDeviceVariablePointerFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceVariablePointerFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceVariablePointerFeatures& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceVariablePointerFeatures& setVariablePointersStorageBuffer( Bool32 variablePointersStorageBuffer_ )\r
+ {\r
+ variablePointersStorageBuffer = variablePointersStorageBuffer_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceVariablePointerFeatures& setVariablePointers( Bool32 variablePointers_ )\r
+ {\r
+ variablePointers = variablePointers_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceVariablePointerFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceVariablePointerFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceVariablePointerFeatures const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( variablePointersStorageBuffer == rhs.variablePointersStorageBuffer )\r
+ && ( variablePointers == rhs.variablePointers );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceVariablePointerFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceVariablePointerFeatures;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 variablePointersStorageBuffer;\r
+ Bool32 variablePointers;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceVariablePointerFeatures ) == sizeof( VkPhysicalDeviceVariablePointerFeatures ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceVariablePointerFeaturesKHR = PhysicalDeviceVariablePointerFeatures;\r
+\r
+ struct PhysicalDeviceIDProperties\r
+ {\r
+ operator const VkPhysicalDeviceIDProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceIDProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceIDProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memcmp( deviceUUID, rhs.deviceUUID, VK_UUID_SIZE * sizeof( uint8_t ) ) == 0 )\r
+ && ( memcmp( driverUUID, rhs.driverUUID, VK_UUID_SIZE * sizeof( uint8_t ) ) == 0 )\r
+ && ( memcmp( deviceLUID, rhs.deviceLUID, VK_LUID_SIZE * sizeof( uint8_t ) ) == 0 )\r
+ && ( deviceNodeMask == rhs.deviceNodeMask )\r
+ && ( deviceLUIDValid == rhs.deviceLUIDValid );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceIDProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceIdProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint8_t deviceUUID[VK_UUID_SIZE];\r
+ uint8_t driverUUID[VK_UUID_SIZE];\r
+ uint8_t deviceLUID[VK_LUID_SIZE];\r
+ uint32_t deviceNodeMask;\r
+ Bool32 deviceLUIDValid;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceIDProperties ) == sizeof( VkPhysicalDeviceIDProperties ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceIDPropertiesKHR = PhysicalDeviceIDProperties;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct ExportMemoryWin32HandleInfoKHR\r
+ {\r
+ ExportMemoryWin32HandleInfoKHR( const SECURITY_ATTRIBUTES* pAttributes_ = nullptr, DWORD dwAccess_ = 0, LPCWSTR name_ = 0 )\r
+ : pAttributes( pAttributes_ )\r
+ , dwAccess( dwAccess_ )\r
+ , name( name_ )\r
+ {\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoKHR( VkExportMemoryWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoKHR& operator=( VkExportMemoryWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ExportMemoryWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoKHR& setPAttributes( const SECURITY_ATTRIBUTES* pAttributes_ )\r
+ {\r
+ pAttributes = pAttributes_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoKHR& setDwAccess( DWORD dwAccess_ )\r
+ {\r
+ dwAccess = dwAccess_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryWin32HandleInfoKHR& setName( LPCWSTR name_ )\r
+ {\r
+ name = name_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportMemoryWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportMemoryWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ExportMemoryWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pAttributes == rhs.pAttributes )\r
+ && ( dwAccess == rhs.dwAccess )\r
+ && ( name == rhs.name );\r
+ }\r
+\r
+ bool operator!=( ExportMemoryWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportMemoryWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const SECURITY_ATTRIBUTES* pAttributes;\r
+ DWORD dwAccess;\r
+ LPCWSTR name;\r
+ };\r
+ static_assert( sizeof( ExportMemoryWin32HandleInfoKHR ) == sizeof( VkExportMemoryWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct MemoryWin32HandlePropertiesKHR\r
+ {\r
+ operator const VkMemoryWin32HandlePropertiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryWin32HandlePropertiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryWin32HandlePropertiesKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memoryTypeBits == rhs.memoryTypeBits );\r
+ }\r
+\r
+ bool operator!=( MemoryWin32HandlePropertiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryWin32HandlePropertiesKHR;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t memoryTypeBits;\r
+ };\r
+ static_assert( sizeof( MemoryWin32HandlePropertiesKHR ) == sizeof( VkMemoryWin32HandlePropertiesKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct MemoryFdPropertiesKHR\r
+ {\r
+ operator const VkMemoryFdPropertiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryFdPropertiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryFdPropertiesKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memoryTypeBits == rhs.memoryTypeBits );\r
+ }\r
+\r
+ bool operator!=( MemoryFdPropertiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryFdPropertiesKHR;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t memoryTypeBits;\r
+ };\r
+ static_assert( sizeof( MemoryFdPropertiesKHR ) == sizeof( VkMemoryFdPropertiesKHR ), "struct and wrapper have different size!" );\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct Win32KeyedMutexAcquireReleaseInfoKHR\r
+ {\r
+ Win32KeyedMutexAcquireReleaseInfoKHR( uint32_t acquireCount_ = 0, const DeviceMemory* pAcquireSyncs_ = nullptr, const uint64_t* pAcquireKeys_ = nullptr, const uint32_t* pAcquireTimeouts_ = nullptr, uint32_t releaseCount_ = 0, const DeviceMemory* pReleaseSyncs_ = nullptr, const uint64_t* pReleaseKeys_ = nullptr )\r
+ : acquireCount( acquireCount_ )\r
+ , pAcquireSyncs( pAcquireSyncs_ )\r
+ , pAcquireKeys( pAcquireKeys_ )\r
+ , pAcquireTimeouts( pAcquireTimeouts_ )\r
+ , releaseCount( releaseCount_ )\r
+ , pReleaseSyncs( pReleaseSyncs_ )\r
+ , pReleaseKeys( pReleaseKeys_ )\r
+ {\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR( VkWin32KeyedMutexAcquireReleaseInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Win32KeyedMutexAcquireReleaseInfoKHR ) );\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& operator=( VkWin32KeyedMutexAcquireReleaseInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( Win32KeyedMutexAcquireReleaseInfoKHR ) );\r
+ return *this;\r
+ }\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setAcquireCount( uint32_t acquireCount_ )\r
+ {\r
+ acquireCount = acquireCount_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setPAcquireSyncs( const DeviceMemory* pAcquireSyncs_ )\r
+ {\r
+ pAcquireSyncs = pAcquireSyncs_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setPAcquireKeys( const uint64_t* pAcquireKeys_ )\r
+ {\r
+ pAcquireKeys = pAcquireKeys_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setPAcquireTimeouts( const uint32_t* pAcquireTimeouts_ )\r
+ {\r
+ pAcquireTimeouts = pAcquireTimeouts_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setReleaseCount( uint32_t releaseCount_ )\r
+ {\r
+ releaseCount = releaseCount_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setPReleaseSyncs( const DeviceMemory* pReleaseSyncs_ )\r
+ {\r
+ pReleaseSyncs = pReleaseSyncs_;\r
+ return *this;\r
+ }\r
+\r
+ Win32KeyedMutexAcquireReleaseInfoKHR& setPReleaseKeys( const uint64_t* pReleaseKeys_ )\r
+ {\r
+ pReleaseKeys = pReleaseKeys_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkWin32KeyedMutexAcquireReleaseInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkWin32KeyedMutexAcquireReleaseInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( Win32KeyedMutexAcquireReleaseInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( acquireCount == rhs.acquireCount )\r
+ && ( pAcquireSyncs == rhs.pAcquireSyncs )\r
+ && ( pAcquireKeys == rhs.pAcquireKeys )\r
+ && ( pAcquireTimeouts == rhs.pAcquireTimeouts )\r
+ && ( releaseCount == rhs.releaseCount )\r
+ && ( pReleaseSyncs == rhs.pReleaseSyncs )\r
+ && ( pReleaseKeys == rhs.pReleaseKeys );\r
+ }\r
+\r
+ bool operator!=( Win32KeyedMutexAcquireReleaseInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eWin32KeyedMutexAcquireReleaseInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t acquireCount;\r
+ const DeviceMemory* pAcquireSyncs;\r
+ const uint64_t* pAcquireKeys;\r
+ const uint32_t* pAcquireTimeouts;\r
+ uint32_t releaseCount;\r
+ const DeviceMemory* pReleaseSyncs;\r
+ const uint64_t* pReleaseKeys;\r
+ };\r
+ static_assert( sizeof( Win32KeyedMutexAcquireReleaseInfoKHR ) == sizeof( VkWin32KeyedMutexAcquireReleaseInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct ExportSemaphoreWin32HandleInfoKHR\r
+ {\r
+ ExportSemaphoreWin32HandleInfoKHR( const SECURITY_ATTRIBUTES* pAttributes_ = nullptr, DWORD dwAccess_ = 0, LPCWSTR name_ = 0 )\r
+ : pAttributes( pAttributes_ )\r
+ , dwAccess( dwAccess_ )\r
+ , name( name_ )\r
+ {\r
+ }\r
+\r
+ ExportSemaphoreWin32HandleInfoKHR( VkExportSemaphoreWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportSemaphoreWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ ExportSemaphoreWin32HandleInfoKHR& operator=( VkExportSemaphoreWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportSemaphoreWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ExportSemaphoreWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportSemaphoreWin32HandleInfoKHR& setPAttributes( const SECURITY_ATTRIBUTES* pAttributes_ )\r
+ {\r
+ pAttributes = pAttributes_;\r
+ return *this;\r
+ }\r
+\r
+ ExportSemaphoreWin32HandleInfoKHR& setDwAccess( DWORD dwAccess_ )\r
+ {\r
+ dwAccess = dwAccess_;\r
+ return *this;\r
+ }\r
+\r
+ ExportSemaphoreWin32HandleInfoKHR& setName( LPCWSTR name_ )\r
+ {\r
+ name = name_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportSemaphoreWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportSemaphoreWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ExportSemaphoreWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pAttributes == rhs.pAttributes )\r
+ && ( dwAccess == rhs.dwAccess )\r
+ && ( name == rhs.name );\r
+ }\r
+\r
+ bool operator!=( ExportSemaphoreWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportSemaphoreWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const SECURITY_ATTRIBUTES* pAttributes;\r
+ DWORD dwAccess;\r
+ LPCWSTR name;\r
+ };\r
+ static_assert( sizeof( ExportSemaphoreWin32HandleInfoKHR ) == sizeof( VkExportSemaphoreWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct D3D12FenceSubmitInfoKHR\r
+ {\r
+ D3D12FenceSubmitInfoKHR( uint32_t waitSemaphoreValuesCount_ = 0, const uint64_t* pWaitSemaphoreValues_ = nullptr, uint32_t signalSemaphoreValuesCount_ = 0, const uint64_t* pSignalSemaphoreValues_ = nullptr )\r
+ : waitSemaphoreValuesCount( waitSemaphoreValuesCount_ )\r
+ , pWaitSemaphoreValues( pWaitSemaphoreValues_ )\r
+ , signalSemaphoreValuesCount( signalSemaphoreValuesCount_ )\r
+ , pSignalSemaphoreValues( pSignalSemaphoreValues_ )\r
+ {\r
+ }\r
+\r
+ D3D12FenceSubmitInfoKHR( VkD3D12FenceSubmitInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( D3D12FenceSubmitInfoKHR ) );\r
+ }\r
+\r
+ D3D12FenceSubmitInfoKHR& operator=( VkD3D12FenceSubmitInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( D3D12FenceSubmitInfoKHR ) );\r
+ return *this;\r
+ }\r
+ D3D12FenceSubmitInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ D3D12FenceSubmitInfoKHR& setWaitSemaphoreValuesCount( uint32_t waitSemaphoreValuesCount_ )\r
+ {\r
+ waitSemaphoreValuesCount = waitSemaphoreValuesCount_;\r
+ return *this;\r
+ }\r
+\r
+ D3D12FenceSubmitInfoKHR& setPWaitSemaphoreValues( const uint64_t* pWaitSemaphoreValues_ )\r
+ {\r
+ pWaitSemaphoreValues = pWaitSemaphoreValues_;\r
+ return *this;\r
+ }\r
+\r
+ D3D12FenceSubmitInfoKHR& setSignalSemaphoreValuesCount( uint32_t signalSemaphoreValuesCount_ )\r
+ {\r
+ signalSemaphoreValuesCount = signalSemaphoreValuesCount_;\r
+ return *this;\r
+ }\r
+\r
+ D3D12FenceSubmitInfoKHR& setPSignalSemaphoreValues( const uint64_t* pSignalSemaphoreValues_ )\r
+ {\r
+ pSignalSemaphoreValues = pSignalSemaphoreValues_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkD3D12FenceSubmitInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkD3D12FenceSubmitInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( D3D12FenceSubmitInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( waitSemaphoreValuesCount == rhs.waitSemaphoreValuesCount )\r
+ && ( pWaitSemaphoreValues == rhs.pWaitSemaphoreValues )\r
+ && ( signalSemaphoreValuesCount == rhs.signalSemaphoreValuesCount )\r
+ && ( pSignalSemaphoreValues == rhs.pSignalSemaphoreValues );\r
+ }\r
+\r
+ bool operator!=( D3D12FenceSubmitInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eD3D12FenceSubmitInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t waitSemaphoreValuesCount;\r
+ const uint64_t* pWaitSemaphoreValues;\r
+ uint32_t signalSemaphoreValuesCount;\r
+ const uint64_t* pSignalSemaphoreValues;\r
+ };\r
+ static_assert( sizeof( D3D12FenceSubmitInfoKHR ) == sizeof( VkD3D12FenceSubmitInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct ExportFenceWin32HandleInfoKHR\r
+ {\r
+ ExportFenceWin32HandleInfoKHR( const SECURITY_ATTRIBUTES* pAttributes_ = nullptr, DWORD dwAccess_ = 0, LPCWSTR name_ = 0 )\r
+ : pAttributes( pAttributes_ )\r
+ , dwAccess( dwAccess_ )\r
+ , name( name_ )\r
+ {\r
+ }\r
+\r
+ ExportFenceWin32HandleInfoKHR( VkExportFenceWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportFenceWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ ExportFenceWin32HandleInfoKHR& operator=( VkExportFenceWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportFenceWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ExportFenceWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportFenceWin32HandleInfoKHR& setPAttributes( const SECURITY_ATTRIBUTES* pAttributes_ )\r
+ {\r
+ pAttributes = pAttributes_;\r
+ return *this;\r
+ }\r
+\r
+ ExportFenceWin32HandleInfoKHR& setDwAccess( DWORD dwAccess_ )\r
+ {\r
+ dwAccess = dwAccess_;\r
+ return *this;\r
+ }\r
+\r
+ ExportFenceWin32HandleInfoKHR& setName( LPCWSTR name_ )\r
+ {\r
+ name = name_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportFenceWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportFenceWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ExportFenceWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pAttributes == rhs.pAttributes )\r
+ && ( dwAccess == rhs.dwAccess )\r
+ && ( name == rhs.name );\r
+ }\r
+\r
+ bool operator!=( ExportFenceWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportFenceWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const SECURITY_ATTRIBUTES* pAttributes;\r
+ DWORD dwAccess;\r
+ LPCWSTR name;\r
+ };\r
+ static_assert( sizeof( ExportFenceWin32HandleInfoKHR ) == sizeof( VkExportFenceWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct PhysicalDeviceMultiviewFeatures\r
+ {\r
+ PhysicalDeviceMultiviewFeatures( Bool32 multiview_ = 0, Bool32 multiviewGeometryShader_ = 0, Bool32 multiviewTessellationShader_ = 0 )\r
+ : multiview( multiview_ )\r
+ , multiviewGeometryShader( multiviewGeometryShader_ )\r
+ , multiviewTessellationShader( multiviewTessellationShader_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceMultiviewFeatures( VkPhysicalDeviceMultiviewFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceMultiviewFeatures ) );\r
+ }\r
+\r
+ PhysicalDeviceMultiviewFeatures& operator=( VkPhysicalDeviceMultiviewFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceMultiviewFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceMultiviewFeatures& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceMultiviewFeatures& setMultiview( Bool32 multiview_ )\r
+ {\r
+ multiview = multiview_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceMultiviewFeatures& setMultiviewGeometryShader( Bool32 multiviewGeometryShader_ )\r
+ {\r
+ multiviewGeometryShader = multiviewGeometryShader_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceMultiviewFeatures& setMultiviewTessellationShader( Bool32 multiviewTessellationShader_ )\r
+ {\r
+ multiviewTessellationShader = multiviewTessellationShader_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceMultiviewFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceMultiviewFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceMultiviewFeatures const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( multiview == rhs.multiview )\r
+ && ( multiviewGeometryShader == rhs.multiviewGeometryShader )\r
+ && ( multiviewTessellationShader == rhs.multiviewTessellationShader );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceMultiviewFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceMultiviewFeatures;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 multiview;\r
+ Bool32 multiviewGeometryShader;\r
+ Bool32 multiviewTessellationShader;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceMultiviewFeatures ) == sizeof( VkPhysicalDeviceMultiviewFeatures ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceMultiviewFeaturesKHR = PhysicalDeviceMultiviewFeatures;\r
+\r
+ struct PhysicalDeviceMultiviewProperties\r
+ {\r
+ operator const VkPhysicalDeviceMultiviewProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceMultiviewProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceMultiviewProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxMultiviewViewCount == rhs.maxMultiviewViewCount )\r
+ && ( maxMultiviewInstanceIndex == rhs.maxMultiviewInstanceIndex );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceMultiviewProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceMultiviewProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxMultiviewViewCount;\r
+ uint32_t maxMultiviewInstanceIndex;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceMultiviewProperties ) == sizeof( VkPhysicalDeviceMultiviewProperties ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceMultiviewPropertiesKHR = PhysicalDeviceMultiviewProperties;\r
+\r
+ struct RenderPassMultiviewCreateInfo\r
+ {\r
+ RenderPassMultiviewCreateInfo( uint32_t subpassCount_ = 0, const uint32_t* pViewMasks_ = nullptr, uint32_t dependencyCount_ = 0, const int32_t* pViewOffsets_ = nullptr, uint32_t correlationMaskCount_ = 0, const uint32_t* pCorrelationMasks_ = nullptr )\r
+ : subpassCount( subpassCount_ )\r
+ , pViewMasks( pViewMasks_ )\r
+ , dependencyCount( dependencyCount_ )\r
+ , pViewOffsets( pViewOffsets_ )\r
+ , correlationMaskCount( correlationMaskCount_ )\r
+ , pCorrelationMasks( pCorrelationMasks_ )\r
+ {\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo( VkRenderPassMultiviewCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassMultiviewCreateInfo ) );\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& operator=( VkRenderPassMultiviewCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassMultiviewCreateInfo ) );\r
+ return *this;\r
+ }\r
+ RenderPassMultiviewCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& setSubpassCount( uint32_t subpassCount_ )\r
+ {\r
+ subpassCount = subpassCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& setPViewMasks( const uint32_t* pViewMasks_ )\r
+ {\r
+ pViewMasks = pViewMasks_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& setDependencyCount( uint32_t dependencyCount_ )\r
+ {\r
+ dependencyCount = dependencyCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& setPViewOffsets( const int32_t* pViewOffsets_ )\r
+ {\r
+ pViewOffsets = pViewOffsets_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& setCorrelationMaskCount( uint32_t correlationMaskCount_ )\r
+ {\r
+ correlationMaskCount = correlationMaskCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassMultiviewCreateInfo& setPCorrelationMasks( const uint32_t* pCorrelationMasks_ )\r
+ {\r
+ pCorrelationMasks = pCorrelationMasks_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRenderPassMultiviewCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkRenderPassMultiviewCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( RenderPassMultiviewCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( subpassCount == rhs.subpassCount )\r
+ && ( pViewMasks == rhs.pViewMasks )\r
+ && ( dependencyCount == rhs.dependencyCount )\r
+ && ( pViewOffsets == rhs.pViewOffsets )\r
+ && ( correlationMaskCount == rhs.correlationMaskCount )\r
+ && ( pCorrelationMasks == rhs.pCorrelationMasks );\r
+ }\r
+\r
+ bool operator!=( RenderPassMultiviewCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eRenderPassMultiviewCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t subpassCount;\r
+ const uint32_t* pViewMasks;\r
+ uint32_t dependencyCount;\r
+ const int32_t* pViewOffsets;\r
+ uint32_t correlationMaskCount;\r
+ const uint32_t* pCorrelationMasks;\r
+ };\r
+ static_assert( sizeof( RenderPassMultiviewCreateInfo ) == sizeof( VkRenderPassMultiviewCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using RenderPassMultiviewCreateInfoKHR = RenderPassMultiviewCreateInfo;\r
+\r
+ struct BindBufferMemoryInfo\r
+ {\r
+ BindBufferMemoryInfo( Buffer buffer_ = Buffer(), DeviceMemory memory_ = DeviceMemory(), DeviceSize memoryOffset_ = 0 )\r
+ : buffer( buffer_ )\r
+ , memory( memory_ )\r
+ , memoryOffset( memoryOffset_ )\r
+ {\r
+ }\r
+\r
+ BindBufferMemoryInfo( VkBindBufferMemoryInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindBufferMemoryInfo ) );\r
+ }\r
+\r
+ BindBufferMemoryInfo& operator=( VkBindBufferMemoryInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindBufferMemoryInfo ) );\r
+ return *this;\r
+ }\r
+ BindBufferMemoryInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindBufferMemoryInfo& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ BindBufferMemoryInfo& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ BindBufferMemoryInfo& setMemoryOffset( DeviceSize memoryOffset_ )\r
+ {\r
+ memoryOffset = memoryOffset_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindBufferMemoryInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindBufferMemoryInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BindBufferMemoryInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( buffer == rhs.buffer )\r
+ && ( memory == rhs.memory )\r
+ && ( memoryOffset == rhs.memoryOffset );\r
+ }\r
+\r
+ bool operator!=( BindBufferMemoryInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindBufferMemoryInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Buffer buffer;\r
+ DeviceMemory memory;\r
+ DeviceSize memoryOffset;\r
+ };\r
+ static_assert( sizeof( BindBufferMemoryInfo ) == sizeof( VkBindBufferMemoryInfo ), "struct and wrapper have different size!" );\r
+\r
+ using BindBufferMemoryInfoKHR = BindBufferMemoryInfo;\r
+\r
+ struct BindBufferMemoryDeviceGroupInfo\r
+ {\r
+ BindBufferMemoryDeviceGroupInfo( uint32_t deviceIndexCount_ = 0, const uint32_t* pDeviceIndices_ = nullptr )\r
+ : deviceIndexCount( deviceIndexCount_ )\r
+ , pDeviceIndices( pDeviceIndices_ )\r
+ {\r
+ }\r
+\r
+ BindBufferMemoryDeviceGroupInfo( VkBindBufferMemoryDeviceGroupInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindBufferMemoryDeviceGroupInfo ) );\r
+ }\r
+\r
+ BindBufferMemoryDeviceGroupInfo& operator=( VkBindBufferMemoryDeviceGroupInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindBufferMemoryDeviceGroupInfo ) );\r
+ return *this;\r
+ }\r
+ BindBufferMemoryDeviceGroupInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindBufferMemoryDeviceGroupInfo& setDeviceIndexCount( uint32_t deviceIndexCount_ )\r
+ {\r
+ deviceIndexCount = deviceIndexCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindBufferMemoryDeviceGroupInfo& setPDeviceIndices( const uint32_t* pDeviceIndices_ )\r
+ {\r
+ pDeviceIndices = pDeviceIndices_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindBufferMemoryDeviceGroupInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindBufferMemoryDeviceGroupInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BindBufferMemoryDeviceGroupInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( deviceIndexCount == rhs.deviceIndexCount )\r
+ && ( pDeviceIndices == rhs.pDeviceIndices );\r
+ }\r
+\r
+ bool operator!=( BindBufferMemoryDeviceGroupInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindBufferMemoryDeviceGroupInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t deviceIndexCount;\r
+ const uint32_t* pDeviceIndices;\r
+ };\r
+ static_assert( sizeof( BindBufferMemoryDeviceGroupInfo ) == sizeof( VkBindBufferMemoryDeviceGroupInfo ), "struct and wrapper have different size!" );\r
+\r
+ using BindBufferMemoryDeviceGroupInfoKHR = BindBufferMemoryDeviceGroupInfo;\r
+\r
+ struct BindImageMemoryInfo\r
+ {\r
+ BindImageMemoryInfo( Image image_ = Image(), DeviceMemory memory_ = DeviceMemory(), DeviceSize memoryOffset_ = 0 )\r
+ : image( image_ )\r
+ , memory( memory_ )\r
+ , memoryOffset( memoryOffset_ )\r
+ {\r
+ }\r
+\r
+ BindImageMemoryInfo( VkBindImageMemoryInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImageMemoryInfo ) );\r
+ }\r
+\r
+ BindImageMemoryInfo& operator=( VkBindImageMemoryInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImageMemoryInfo ) );\r
+ return *this;\r
+ }\r
+ BindImageMemoryInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryInfo& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryInfo& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryInfo& setMemoryOffset( DeviceSize memoryOffset_ )\r
+ {\r
+ memoryOffset = memoryOffset_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindImageMemoryInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindImageMemoryInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BindImageMemoryInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( image == rhs.image )\r
+ && ( memory == rhs.memory )\r
+ && ( memoryOffset == rhs.memoryOffset );\r
+ }\r
+\r
+ bool operator!=( BindImageMemoryInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindImageMemoryInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Image image;\r
+ DeviceMemory memory;\r
+ DeviceSize memoryOffset;\r
+ };\r
+ static_assert( sizeof( BindImageMemoryInfo ) == sizeof( VkBindImageMemoryInfo ), "struct and wrapper have different size!" );\r
+\r
+ using BindImageMemoryInfoKHR = BindImageMemoryInfo;\r
+\r
+ struct BindImageMemoryDeviceGroupInfo\r
+ {\r
+ BindImageMemoryDeviceGroupInfo( uint32_t deviceIndexCount_ = 0, const uint32_t* pDeviceIndices_ = nullptr, uint32_t splitInstanceBindRegionCount_ = 0, const Rect2D* pSplitInstanceBindRegions_ = nullptr )\r
+ : deviceIndexCount( deviceIndexCount_ )\r
+ , pDeviceIndices( pDeviceIndices_ )\r
+ , splitInstanceBindRegionCount( splitInstanceBindRegionCount_ )\r
+ , pSplitInstanceBindRegions( pSplitInstanceBindRegions_ )\r
+ {\r
+ }\r
+\r
+ BindImageMemoryDeviceGroupInfo( VkBindImageMemoryDeviceGroupInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImageMemoryDeviceGroupInfo ) );\r
+ }\r
+\r
+ BindImageMemoryDeviceGroupInfo& operator=( VkBindImageMemoryDeviceGroupInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImageMemoryDeviceGroupInfo ) );\r
+ return *this;\r
+ }\r
+ BindImageMemoryDeviceGroupInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryDeviceGroupInfo& setDeviceIndexCount( uint32_t deviceIndexCount_ )\r
+ {\r
+ deviceIndexCount = deviceIndexCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryDeviceGroupInfo& setPDeviceIndices( const uint32_t* pDeviceIndices_ )\r
+ {\r
+ pDeviceIndices = pDeviceIndices_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryDeviceGroupInfo& setSplitInstanceBindRegionCount( uint32_t splitInstanceBindRegionCount_ )\r
+ {\r
+ splitInstanceBindRegionCount = splitInstanceBindRegionCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemoryDeviceGroupInfo& setPSplitInstanceBindRegions( const Rect2D* pSplitInstanceBindRegions_ )\r
+ {\r
+ pSplitInstanceBindRegions = pSplitInstanceBindRegions_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindImageMemoryDeviceGroupInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindImageMemoryDeviceGroupInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BindImageMemoryDeviceGroupInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( deviceIndexCount == rhs.deviceIndexCount )\r
+ && ( pDeviceIndices == rhs.pDeviceIndices )\r
+ && ( splitInstanceBindRegionCount == rhs.splitInstanceBindRegionCount )\r
+ && ( pSplitInstanceBindRegions == rhs.pSplitInstanceBindRegions );\r
+ }\r
+\r
+ bool operator!=( BindImageMemoryDeviceGroupInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindImageMemoryDeviceGroupInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t deviceIndexCount;\r
+ const uint32_t* pDeviceIndices;\r
+ uint32_t splitInstanceBindRegionCount;\r
+ const Rect2D* pSplitInstanceBindRegions;\r
+ };\r
+ static_assert( sizeof( BindImageMemoryDeviceGroupInfo ) == sizeof( VkBindImageMemoryDeviceGroupInfo ), "struct and wrapper have different size!" );\r
+\r
+ using BindImageMemoryDeviceGroupInfoKHR = BindImageMemoryDeviceGroupInfo;\r
+\r
+ struct DeviceGroupRenderPassBeginInfo\r
+ {\r
+ DeviceGroupRenderPassBeginInfo( uint32_t deviceMask_ = 0, uint32_t deviceRenderAreaCount_ = 0, const Rect2D* pDeviceRenderAreas_ = nullptr )\r
+ : deviceMask( deviceMask_ )\r
+ , deviceRenderAreaCount( deviceRenderAreaCount_ )\r
+ , pDeviceRenderAreas( pDeviceRenderAreas_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupRenderPassBeginInfo( VkDeviceGroupRenderPassBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupRenderPassBeginInfo ) );\r
+ }\r
+\r
+ DeviceGroupRenderPassBeginInfo& operator=( VkDeviceGroupRenderPassBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupRenderPassBeginInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupRenderPassBeginInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupRenderPassBeginInfo& setDeviceMask( uint32_t deviceMask_ )\r
+ {\r
+ deviceMask = deviceMask_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupRenderPassBeginInfo& setDeviceRenderAreaCount( uint32_t deviceRenderAreaCount_ )\r
+ {\r
+ deviceRenderAreaCount = deviceRenderAreaCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupRenderPassBeginInfo& setPDeviceRenderAreas( const Rect2D* pDeviceRenderAreas_ )\r
+ {\r
+ pDeviceRenderAreas = pDeviceRenderAreas_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupRenderPassBeginInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupRenderPassBeginInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupRenderPassBeginInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( deviceMask == rhs.deviceMask )\r
+ && ( deviceRenderAreaCount == rhs.deviceRenderAreaCount )\r
+ && ( pDeviceRenderAreas == rhs.pDeviceRenderAreas );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupRenderPassBeginInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupRenderPassBeginInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t deviceMask;\r
+ uint32_t deviceRenderAreaCount;\r
+ const Rect2D* pDeviceRenderAreas;\r
+ };\r
+ static_assert( sizeof( DeviceGroupRenderPassBeginInfo ) == sizeof( VkDeviceGroupRenderPassBeginInfo ), "struct and wrapper have different size!" );\r
+\r
+ using DeviceGroupRenderPassBeginInfoKHR = DeviceGroupRenderPassBeginInfo;\r
+\r
+ struct DeviceGroupCommandBufferBeginInfo\r
+ {\r
+ DeviceGroupCommandBufferBeginInfo( uint32_t deviceMask_ = 0 )\r
+ : deviceMask( deviceMask_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupCommandBufferBeginInfo( VkDeviceGroupCommandBufferBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupCommandBufferBeginInfo ) );\r
+ }\r
+\r
+ DeviceGroupCommandBufferBeginInfo& operator=( VkDeviceGroupCommandBufferBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupCommandBufferBeginInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupCommandBufferBeginInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupCommandBufferBeginInfo& setDeviceMask( uint32_t deviceMask_ )\r
+ {\r
+ deviceMask = deviceMask_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupCommandBufferBeginInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupCommandBufferBeginInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupCommandBufferBeginInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( deviceMask == rhs.deviceMask );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupCommandBufferBeginInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupCommandBufferBeginInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t deviceMask;\r
+ };\r
+ static_assert( sizeof( DeviceGroupCommandBufferBeginInfo ) == sizeof( VkDeviceGroupCommandBufferBeginInfo ), "struct and wrapper have different size!" );\r
+\r
+ using DeviceGroupCommandBufferBeginInfoKHR = DeviceGroupCommandBufferBeginInfo;\r
+\r
+ struct DeviceGroupSubmitInfo\r
+ {\r
+ DeviceGroupSubmitInfo( uint32_t waitSemaphoreCount_ = 0, const uint32_t* pWaitSemaphoreDeviceIndices_ = nullptr, uint32_t commandBufferCount_ = 0, const uint32_t* pCommandBufferDeviceMasks_ = nullptr, uint32_t signalSemaphoreCount_ = 0, const uint32_t* pSignalSemaphoreDeviceIndices_ = nullptr )\r
+ : waitSemaphoreCount( waitSemaphoreCount_ )\r
+ , pWaitSemaphoreDeviceIndices( pWaitSemaphoreDeviceIndices_ )\r
+ , commandBufferCount( commandBufferCount_ )\r
+ , pCommandBufferDeviceMasks( pCommandBufferDeviceMasks_ )\r
+ , signalSemaphoreCount( signalSemaphoreCount_ )\r
+ , pSignalSemaphoreDeviceIndices( pSignalSemaphoreDeviceIndices_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupSubmitInfo( VkDeviceGroupSubmitInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupSubmitInfo ) );\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& operator=( VkDeviceGroupSubmitInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupSubmitInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupSubmitInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& setWaitSemaphoreCount( uint32_t waitSemaphoreCount_ )\r
+ {\r
+ waitSemaphoreCount = waitSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& setPWaitSemaphoreDeviceIndices( const uint32_t* pWaitSemaphoreDeviceIndices_ )\r
+ {\r
+ pWaitSemaphoreDeviceIndices = pWaitSemaphoreDeviceIndices_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& setCommandBufferCount( uint32_t commandBufferCount_ )\r
+ {\r
+ commandBufferCount = commandBufferCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& setPCommandBufferDeviceMasks( const uint32_t* pCommandBufferDeviceMasks_ )\r
+ {\r
+ pCommandBufferDeviceMasks = pCommandBufferDeviceMasks_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& setSignalSemaphoreCount( uint32_t signalSemaphoreCount_ )\r
+ {\r
+ signalSemaphoreCount = signalSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSubmitInfo& setPSignalSemaphoreDeviceIndices( const uint32_t* pSignalSemaphoreDeviceIndices_ )\r
+ {\r
+ pSignalSemaphoreDeviceIndices = pSignalSemaphoreDeviceIndices_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupSubmitInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupSubmitInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupSubmitInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( waitSemaphoreCount == rhs.waitSemaphoreCount )\r
+ && ( pWaitSemaphoreDeviceIndices == rhs.pWaitSemaphoreDeviceIndices )\r
+ && ( commandBufferCount == rhs.commandBufferCount )\r
+ && ( pCommandBufferDeviceMasks == rhs.pCommandBufferDeviceMasks )\r
+ && ( signalSemaphoreCount == rhs.signalSemaphoreCount )\r
+ && ( pSignalSemaphoreDeviceIndices == rhs.pSignalSemaphoreDeviceIndices );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupSubmitInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupSubmitInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t waitSemaphoreCount;\r
+ const uint32_t* pWaitSemaphoreDeviceIndices;\r
+ uint32_t commandBufferCount;\r
+ const uint32_t* pCommandBufferDeviceMasks;\r
+ uint32_t signalSemaphoreCount;\r
+ const uint32_t* pSignalSemaphoreDeviceIndices;\r
+ };\r
+ static_assert( sizeof( DeviceGroupSubmitInfo ) == sizeof( VkDeviceGroupSubmitInfo ), "struct and wrapper have different size!" );\r
+\r
+ using DeviceGroupSubmitInfoKHR = DeviceGroupSubmitInfo;\r
+\r
+ struct DeviceGroupBindSparseInfo\r
+ {\r
+ DeviceGroupBindSparseInfo( uint32_t resourceDeviceIndex_ = 0, uint32_t memoryDeviceIndex_ = 0 )\r
+ : resourceDeviceIndex( resourceDeviceIndex_ )\r
+ , memoryDeviceIndex( memoryDeviceIndex_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupBindSparseInfo( VkDeviceGroupBindSparseInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupBindSparseInfo ) );\r
+ }\r
+\r
+ DeviceGroupBindSparseInfo& operator=( VkDeviceGroupBindSparseInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupBindSparseInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupBindSparseInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupBindSparseInfo& setResourceDeviceIndex( uint32_t resourceDeviceIndex_ )\r
+ {\r
+ resourceDeviceIndex = resourceDeviceIndex_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupBindSparseInfo& setMemoryDeviceIndex( uint32_t memoryDeviceIndex_ )\r
+ {\r
+ memoryDeviceIndex = memoryDeviceIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupBindSparseInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupBindSparseInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupBindSparseInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( resourceDeviceIndex == rhs.resourceDeviceIndex )\r
+ && ( memoryDeviceIndex == rhs.memoryDeviceIndex );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupBindSparseInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupBindSparseInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t resourceDeviceIndex;\r
+ uint32_t memoryDeviceIndex;\r
+ };\r
+ static_assert( sizeof( DeviceGroupBindSparseInfo ) == sizeof( VkDeviceGroupBindSparseInfo ), "struct and wrapper have different size!" );\r
+\r
+ using DeviceGroupBindSparseInfoKHR = DeviceGroupBindSparseInfo;\r
+\r
+ struct ImageSwapchainCreateInfoKHR\r
+ {\r
+ ImageSwapchainCreateInfoKHR( SwapchainKHR swapchain_ = SwapchainKHR() )\r
+ : swapchain( swapchain_ )\r
+ {\r
+ }\r
+\r
+ ImageSwapchainCreateInfoKHR( VkImageSwapchainCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSwapchainCreateInfoKHR ) );\r
+ }\r
+\r
+ ImageSwapchainCreateInfoKHR& operator=( VkImageSwapchainCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSwapchainCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImageSwapchainCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSwapchainCreateInfoKHR& setSwapchain( SwapchainKHR swapchain_ )\r
+ {\r
+ swapchain = swapchain_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageSwapchainCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageSwapchainCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImageSwapchainCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( swapchain == rhs.swapchain );\r
+ }\r
+\r
+ bool operator!=( ImageSwapchainCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageSwapchainCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SwapchainKHR swapchain;\r
+ };\r
+ static_assert( sizeof( ImageSwapchainCreateInfoKHR ) == sizeof( VkImageSwapchainCreateInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct BindImageMemorySwapchainInfoKHR\r
+ {\r
+ BindImageMemorySwapchainInfoKHR( SwapchainKHR swapchain_ = SwapchainKHR(), uint32_t imageIndex_ = 0 )\r
+ : swapchain( swapchain_ )\r
+ , imageIndex( imageIndex_ )\r
+ {\r
+ }\r
+\r
+ BindImageMemorySwapchainInfoKHR( VkBindImageMemorySwapchainInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImageMemorySwapchainInfoKHR ) );\r
+ }\r
+\r
+ BindImageMemorySwapchainInfoKHR& operator=( VkBindImageMemorySwapchainInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImageMemorySwapchainInfoKHR ) );\r
+ return *this;\r
+ }\r
+ BindImageMemorySwapchainInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemorySwapchainInfoKHR& setSwapchain( SwapchainKHR swapchain_ )\r
+ {\r
+ swapchain = swapchain_;\r
+ return *this;\r
+ }\r
+\r
+ BindImageMemorySwapchainInfoKHR& setImageIndex( uint32_t imageIndex_ )\r
+ {\r
+ imageIndex = imageIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindImageMemorySwapchainInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindImageMemorySwapchainInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( BindImageMemorySwapchainInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( swapchain == rhs.swapchain )\r
+ && ( imageIndex == rhs.imageIndex );\r
+ }\r
+\r
+ bool operator!=( BindImageMemorySwapchainInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindImageMemorySwapchainInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SwapchainKHR swapchain;\r
+ uint32_t imageIndex;\r
+ };\r
+ static_assert( sizeof( BindImageMemorySwapchainInfoKHR ) == sizeof( VkBindImageMemorySwapchainInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct AcquireNextImageInfoKHR\r
+ {\r
+ AcquireNextImageInfoKHR( SwapchainKHR swapchain_ = SwapchainKHR(), uint64_t timeout_ = 0, Semaphore semaphore_ = Semaphore(), Fence fence_ = Fence(), uint32_t deviceMask_ = 0 )\r
+ : swapchain( swapchain_ )\r
+ , timeout( timeout_ )\r
+ , semaphore( semaphore_ )\r
+ , fence( fence_ )\r
+ , deviceMask( deviceMask_ )\r
+ {\r
+ }\r
+\r
+ AcquireNextImageInfoKHR( VkAcquireNextImageInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AcquireNextImageInfoKHR ) );\r
+ }\r
+\r
+ AcquireNextImageInfoKHR& operator=( VkAcquireNextImageInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AcquireNextImageInfoKHR ) );\r
+ return *this;\r
+ }\r
+ AcquireNextImageInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ AcquireNextImageInfoKHR& setSwapchain( SwapchainKHR swapchain_ )\r
+ {\r
+ swapchain = swapchain_;\r
+ return *this;\r
+ }\r
+\r
+ AcquireNextImageInfoKHR& setTimeout( uint64_t timeout_ )\r
+ {\r
+ timeout = timeout_;\r
+ return *this;\r
+ }\r
+\r
+ AcquireNextImageInfoKHR& setSemaphore( Semaphore semaphore_ )\r
+ {\r
+ semaphore = semaphore_;\r
+ return *this;\r
+ }\r
+\r
+ AcquireNextImageInfoKHR& setFence( Fence fence_ )\r
+ {\r
+ fence = fence_;\r
+ return *this;\r
+ }\r
+\r
+ AcquireNextImageInfoKHR& setDeviceMask( uint32_t deviceMask_ )\r
+ {\r
+ deviceMask = deviceMask_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkAcquireNextImageInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkAcquireNextImageInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( AcquireNextImageInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( swapchain == rhs.swapchain )\r
+ && ( timeout == rhs.timeout )\r
+ && ( semaphore == rhs.semaphore )\r
+ && ( fence == rhs.fence )\r
+ && ( deviceMask == rhs.deviceMask );\r
+ }\r
+\r
+ bool operator!=( AcquireNextImageInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eAcquireNextImageInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SwapchainKHR swapchain;\r
+ uint64_t timeout;\r
+ Semaphore semaphore;\r
+ Fence fence;\r
+ uint32_t deviceMask;\r
+ };\r
+ static_assert( sizeof( AcquireNextImageInfoKHR ) == sizeof( VkAcquireNextImageInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct HdrMetadataEXT\r
+ {\r
+ HdrMetadataEXT( XYColorEXT displayPrimaryRed_ = XYColorEXT(), XYColorEXT displayPrimaryGreen_ = XYColorEXT(), XYColorEXT displayPrimaryBlue_ = XYColorEXT(), XYColorEXT whitePoint_ = XYColorEXT(), float maxLuminance_ = 0, float minLuminance_ = 0, float maxContentLightLevel_ = 0, float maxFrameAverageLightLevel_ = 0 )\r
+ : displayPrimaryRed( displayPrimaryRed_ )\r
+ , displayPrimaryGreen( displayPrimaryGreen_ )\r
+ , displayPrimaryBlue( displayPrimaryBlue_ )\r
+ , whitePoint( whitePoint_ )\r
+ , maxLuminance( maxLuminance_ )\r
+ , minLuminance( minLuminance_ )\r
+ , maxContentLightLevel( maxContentLightLevel_ )\r
+ , maxFrameAverageLightLevel( maxFrameAverageLightLevel_ )\r
+ {\r
+ }\r
+\r
+ HdrMetadataEXT( VkHdrMetadataEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( HdrMetadataEXT ) );\r
+ }\r
+\r
+ HdrMetadataEXT& operator=( VkHdrMetadataEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( HdrMetadataEXT ) );\r
+ return *this;\r
+ }\r
+ HdrMetadataEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setDisplayPrimaryRed( XYColorEXT displayPrimaryRed_ )\r
+ {\r
+ displayPrimaryRed = displayPrimaryRed_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setDisplayPrimaryGreen( XYColorEXT displayPrimaryGreen_ )\r
+ {\r
+ displayPrimaryGreen = displayPrimaryGreen_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setDisplayPrimaryBlue( XYColorEXT displayPrimaryBlue_ )\r
+ {\r
+ displayPrimaryBlue = displayPrimaryBlue_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setWhitePoint( XYColorEXT whitePoint_ )\r
+ {\r
+ whitePoint = whitePoint_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setMaxLuminance( float maxLuminance_ )\r
+ {\r
+ maxLuminance = maxLuminance_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setMinLuminance( float minLuminance_ )\r
+ {\r
+ minLuminance = minLuminance_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setMaxContentLightLevel( float maxContentLightLevel_ )\r
+ {\r
+ maxContentLightLevel = maxContentLightLevel_;\r
+ return *this;\r
+ }\r
+\r
+ HdrMetadataEXT& setMaxFrameAverageLightLevel( float maxFrameAverageLightLevel_ )\r
+ {\r
+ maxFrameAverageLightLevel = maxFrameAverageLightLevel_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkHdrMetadataEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkHdrMetadataEXT*>(this);\r
+ }\r
+\r
+ bool operator==( HdrMetadataEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( displayPrimaryRed == rhs.displayPrimaryRed )\r
+ && ( displayPrimaryGreen == rhs.displayPrimaryGreen )\r
+ && ( displayPrimaryBlue == rhs.displayPrimaryBlue )\r
+ && ( whitePoint == rhs.whitePoint )\r
+ && ( maxLuminance == rhs.maxLuminance )\r
+ && ( minLuminance == rhs.minLuminance )\r
+ && ( maxContentLightLevel == rhs.maxContentLightLevel )\r
+ && ( maxFrameAverageLightLevel == rhs.maxFrameAverageLightLevel );\r
+ }\r
+\r
+ bool operator!=( HdrMetadataEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eHdrMetadataEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ XYColorEXT displayPrimaryRed;\r
+ XYColorEXT displayPrimaryGreen;\r
+ XYColorEXT displayPrimaryBlue;\r
+ XYColorEXT whitePoint;\r
+ float maxLuminance;\r
+ float minLuminance;\r
+ float maxContentLightLevel;\r
+ float maxFrameAverageLightLevel;\r
+ };\r
+ static_assert( sizeof( HdrMetadataEXT ) == sizeof( VkHdrMetadataEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PresentTimesInfoGOOGLE\r
+ {\r
+ PresentTimesInfoGOOGLE( uint32_t swapchainCount_ = 0, const PresentTimeGOOGLE* pTimes_ = nullptr )\r
+ : swapchainCount( swapchainCount_ )\r
+ , pTimes( pTimes_ )\r
+ {\r
+ }\r
+\r
+ PresentTimesInfoGOOGLE( VkPresentTimesInfoGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentTimesInfoGOOGLE ) );\r
+ }\r
+\r
+ PresentTimesInfoGOOGLE& operator=( VkPresentTimesInfoGOOGLE const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentTimesInfoGOOGLE ) );\r
+ return *this;\r
+ }\r
+ PresentTimesInfoGOOGLE& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PresentTimesInfoGOOGLE& setSwapchainCount( uint32_t swapchainCount_ )\r
+ {\r
+ swapchainCount = swapchainCount_;\r
+ return *this;\r
+ }\r
+\r
+ PresentTimesInfoGOOGLE& setPTimes( const PresentTimeGOOGLE* pTimes_ )\r
+ {\r
+ pTimes = pTimes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPresentTimesInfoGOOGLE&() const\r
+ {\r
+ return *reinterpret_cast<const VkPresentTimesInfoGOOGLE*>(this);\r
+ }\r
+\r
+ bool operator==( PresentTimesInfoGOOGLE const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( swapchainCount == rhs.swapchainCount )\r
+ && ( pTimes == rhs.pTimes );\r
+ }\r
+\r
+ bool operator!=( PresentTimesInfoGOOGLE const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePresentTimesInfoGOOGLE;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t swapchainCount;\r
+ const PresentTimeGOOGLE* pTimes;\r
+ };\r
+ static_assert( sizeof( PresentTimesInfoGOOGLE ) == sizeof( VkPresentTimesInfoGOOGLE ), "struct and wrapper have different size!" );\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ struct IOSSurfaceCreateInfoMVK\r
+ {\r
+ IOSSurfaceCreateInfoMVK( IOSSurfaceCreateFlagsMVK flags_ = IOSSurfaceCreateFlagsMVK(), const void* pView_ = nullptr )\r
+ : flags( flags_ )\r
+ , pView( pView_ )\r
+ {\r
+ }\r
+\r
+ IOSSurfaceCreateInfoMVK( VkIOSSurfaceCreateInfoMVK const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IOSSurfaceCreateInfoMVK ) );\r
+ }\r
+\r
+ IOSSurfaceCreateInfoMVK& operator=( VkIOSSurfaceCreateInfoMVK const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IOSSurfaceCreateInfoMVK ) );\r
+ return *this;\r
+ }\r
+ IOSSurfaceCreateInfoMVK& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ IOSSurfaceCreateInfoMVK& setFlags( IOSSurfaceCreateFlagsMVK flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ IOSSurfaceCreateInfoMVK& setPView( const void* pView_ )\r
+ {\r
+ pView = pView_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkIOSSurfaceCreateInfoMVK&() const\r
+ {\r
+ return *reinterpret_cast<const VkIOSSurfaceCreateInfoMVK*>(this);\r
+ }\r
+\r
+ bool operator==( IOSSurfaceCreateInfoMVK const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( pView == rhs.pView );\r
+ }\r
+\r
+ bool operator!=( IOSSurfaceCreateInfoMVK const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eIosSurfaceCreateInfoMVK;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ IOSSurfaceCreateFlagsMVK flags;\r
+ const void* pView;\r
+ };\r
+ static_assert( sizeof( IOSSurfaceCreateInfoMVK ) == sizeof( VkIOSSurfaceCreateInfoMVK ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ struct MacOSSurfaceCreateInfoMVK\r
+ {\r
+ MacOSSurfaceCreateInfoMVK( MacOSSurfaceCreateFlagsMVK flags_ = MacOSSurfaceCreateFlagsMVK(), const void* pView_ = nullptr )\r
+ : flags( flags_ )\r
+ , pView( pView_ )\r
+ {\r
+ }\r
+\r
+ MacOSSurfaceCreateInfoMVK( VkMacOSSurfaceCreateInfoMVK const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MacOSSurfaceCreateInfoMVK ) );\r
+ }\r
+\r
+ MacOSSurfaceCreateInfoMVK& operator=( VkMacOSSurfaceCreateInfoMVK const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MacOSSurfaceCreateInfoMVK ) );\r
+ return *this;\r
+ }\r
+ MacOSSurfaceCreateInfoMVK& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MacOSSurfaceCreateInfoMVK& setFlags( MacOSSurfaceCreateFlagsMVK flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ MacOSSurfaceCreateInfoMVK& setPView( const void* pView_ )\r
+ {\r
+ pView = pView_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMacOSSurfaceCreateInfoMVK&() const\r
+ {\r
+ return *reinterpret_cast<const VkMacOSSurfaceCreateInfoMVK*>(this);\r
+ }\r
+\r
+ bool operator==( MacOSSurfaceCreateInfoMVK const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( pView == rhs.pView );\r
+ }\r
+\r
+ bool operator!=( MacOSSurfaceCreateInfoMVK const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMacosSurfaceCreateInfoMVK;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ MacOSSurfaceCreateFlagsMVK flags;\r
+ const void* pView;\r
+ };\r
+ static_assert( sizeof( MacOSSurfaceCreateInfoMVK ) == sizeof( VkMacOSSurfaceCreateInfoMVK ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+ struct PipelineViewportWScalingStateCreateInfoNV\r
+ {\r
+ PipelineViewportWScalingStateCreateInfoNV( Bool32 viewportWScalingEnable_ = 0, uint32_t viewportCount_ = 0, const ViewportWScalingNV* pViewportWScalings_ = nullptr )\r
+ : viewportWScalingEnable( viewportWScalingEnable_ )\r
+ , viewportCount( viewportCount_ )\r
+ , pViewportWScalings( pViewportWScalings_ )\r
+ {\r
+ }\r
+\r
+ PipelineViewportWScalingStateCreateInfoNV( VkPipelineViewportWScalingStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineViewportWScalingStateCreateInfoNV ) );\r
+ }\r
+\r
+ PipelineViewportWScalingStateCreateInfoNV& operator=( VkPipelineViewportWScalingStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineViewportWScalingStateCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ PipelineViewportWScalingStateCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportWScalingStateCreateInfoNV& setViewportWScalingEnable( Bool32 viewportWScalingEnable_ )\r
+ {\r
+ viewportWScalingEnable = viewportWScalingEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportWScalingStateCreateInfoNV& setViewportCount( uint32_t viewportCount_ )\r
+ {\r
+ viewportCount = viewportCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportWScalingStateCreateInfoNV& setPViewportWScalings( const ViewportWScalingNV* pViewportWScalings_ )\r
+ {\r
+ pViewportWScalings = pViewportWScalings_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineViewportWScalingStateCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineViewportWScalingStateCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineViewportWScalingStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( viewportWScalingEnable == rhs.viewportWScalingEnable )\r
+ && ( viewportCount == rhs.viewportCount )\r
+ && ( pViewportWScalings == rhs.pViewportWScalings );\r
+ }\r
+\r
+ bool operator!=( PipelineViewportWScalingStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineViewportWScalingStateCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 viewportWScalingEnable;\r
+ uint32_t viewportCount;\r
+ const ViewportWScalingNV* pViewportWScalings;\r
+ };\r
+ static_assert( sizeof( PipelineViewportWScalingStateCreateInfoNV ) == sizeof( VkPipelineViewportWScalingStateCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceDiscardRectanglePropertiesEXT\r
+ {\r
+ PhysicalDeviceDiscardRectanglePropertiesEXT( uint32_t maxDiscardRectangles_ = 0 )\r
+ : maxDiscardRectangles( maxDiscardRectangles_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceDiscardRectanglePropertiesEXT( VkPhysicalDeviceDiscardRectanglePropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceDiscardRectanglePropertiesEXT ) );\r
+ }\r
+\r
+ PhysicalDeviceDiscardRectanglePropertiesEXT& operator=( VkPhysicalDeviceDiscardRectanglePropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceDiscardRectanglePropertiesEXT ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceDiscardRectanglePropertiesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDiscardRectanglePropertiesEXT& setMaxDiscardRectangles( uint32_t maxDiscardRectangles_ )\r
+ {\r
+ maxDiscardRectangles = maxDiscardRectangles_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceDiscardRectanglePropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceDiscardRectanglePropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceDiscardRectanglePropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxDiscardRectangles == rhs.maxDiscardRectangles );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceDiscardRectanglePropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceDiscardRectanglePropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxDiscardRectangles;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceDiscardRectanglePropertiesEXT ) == sizeof( VkPhysicalDeviceDiscardRectanglePropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceMultiviewPerViewAttributesPropertiesNVX\r
+ {\r
+ operator const VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceMultiviewPerViewAttributesPropertiesNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( perViewPositionAllComponents == rhs.perViewPositionAllComponents );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceMultiviewPerViewAttributesPropertiesNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceMultiviewPerViewAttributesPropertiesNVX;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 perViewPositionAllComponents;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceMultiviewPerViewAttributesPropertiesNVX ) == sizeof( VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceSurfaceInfo2KHR\r
+ {\r
+ PhysicalDeviceSurfaceInfo2KHR( SurfaceKHR surface_ = SurfaceKHR() )\r
+ : surface( surface_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceSurfaceInfo2KHR( VkPhysicalDeviceSurfaceInfo2KHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceSurfaceInfo2KHR ) );\r
+ }\r
+\r
+ PhysicalDeviceSurfaceInfo2KHR& operator=( VkPhysicalDeviceSurfaceInfo2KHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceSurfaceInfo2KHR ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceSurfaceInfo2KHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSurfaceInfo2KHR& setSurface( SurfaceKHR surface_ )\r
+ {\r
+ surface = surface_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceSurfaceInfo2KHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSurfaceInfo2KHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( surface == rhs.surface );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSurfaceInfo2KHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceSurfaceInfo2KHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SurfaceKHR surface;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSurfaceInfo2KHR ) == sizeof( VkPhysicalDeviceSurfaceInfo2KHR ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDevice16BitStorageFeatures\r
+ {\r
+ PhysicalDevice16BitStorageFeatures( Bool32 storageBuffer16BitAccess_ = 0, Bool32 uniformAndStorageBuffer16BitAccess_ = 0, Bool32 storagePushConstant16_ = 0, Bool32 storageInputOutput16_ = 0 )\r
+ : storageBuffer16BitAccess( storageBuffer16BitAccess_ )\r
+ , uniformAndStorageBuffer16BitAccess( uniformAndStorageBuffer16BitAccess_ )\r
+ , storagePushConstant16( storagePushConstant16_ )\r
+ , storageInputOutput16( storageInputOutput16_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDevice16BitStorageFeatures( VkPhysicalDevice16BitStorageFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDevice16BitStorageFeatures ) );\r
+ }\r
+\r
+ PhysicalDevice16BitStorageFeatures& operator=( VkPhysicalDevice16BitStorageFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDevice16BitStorageFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDevice16BitStorageFeatures& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDevice16BitStorageFeatures& setStorageBuffer16BitAccess( Bool32 storageBuffer16BitAccess_ )\r
+ {\r
+ storageBuffer16BitAccess = storageBuffer16BitAccess_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDevice16BitStorageFeatures& setUniformAndStorageBuffer16BitAccess( Bool32 uniformAndStorageBuffer16BitAccess_ )\r
+ {\r
+ uniformAndStorageBuffer16BitAccess = uniformAndStorageBuffer16BitAccess_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDevice16BitStorageFeatures& setStoragePushConstant16( Bool32 storagePushConstant16_ )\r
+ {\r
+ storagePushConstant16 = storagePushConstant16_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDevice16BitStorageFeatures& setStorageInputOutput16( Bool32 storageInputOutput16_ )\r
+ {\r
+ storageInputOutput16 = storageInputOutput16_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDevice16BitStorageFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDevice16BitStorageFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDevice16BitStorageFeatures const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( storageBuffer16BitAccess == rhs.storageBuffer16BitAccess )\r
+ && ( uniformAndStorageBuffer16BitAccess == rhs.uniformAndStorageBuffer16BitAccess )\r
+ && ( storagePushConstant16 == rhs.storagePushConstant16 )\r
+ && ( storageInputOutput16 == rhs.storageInputOutput16 );\r
+ }\r
+\r
+ bool operator!=( PhysicalDevice16BitStorageFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDevice16BitStorageFeatures;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 storageBuffer16BitAccess;\r
+ Bool32 uniformAndStorageBuffer16BitAccess;\r
+ Bool32 storagePushConstant16;\r
+ Bool32 storageInputOutput16;\r
+ };\r
+ static_assert( sizeof( PhysicalDevice16BitStorageFeatures ) == sizeof( VkPhysicalDevice16BitStorageFeatures ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDevice16BitStorageFeaturesKHR = PhysicalDevice16BitStorageFeatures;\r
+\r
+ struct BufferMemoryRequirementsInfo2\r
+ {\r
+ BufferMemoryRequirementsInfo2( Buffer buffer_ = Buffer() )\r
+ : buffer( buffer_ )\r
+ {\r
+ }\r
+\r
+ BufferMemoryRequirementsInfo2( VkBufferMemoryRequirementsInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferMemoryRequirementsInfo2 ) );\r
+ }\r
+\r
+ BufferMemoryRequirementsInfo2& operator=( VkBufferMemoryRequirementsInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferMemoryRequirementsInfo2 ) );\r
+ return *this;\r
+ }\r
+ BufferMemoryRequirementsInfo2& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryRequirementsInfo2& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBufferMemoryRequirementsInfo2&() const\r
+ {\r
+ return *reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>(this);\r
+ }\r
+\r
+ bool operator==( BufferMemoryRequirementsInfo2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( buffer == rhs.buffer );\r
+ }\r
+\r
+ bool operator!=( BufferMemoryRequirementsInfo2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBufferMemoryRequirementsInfo2;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Buffer buffer;\r
+ };\r
+ static_assert( sizeof( BufferMemoryRequirementsInfo2 ) == sizeof( VkBufferMemoryRequirementsInfo2 ), "struct and wrapper have different size!" );\r
+\r
+ using BufferMemoryRequirementsInfo2KHR = BufferMemoryRequirementsInfo2;\r
+\r
+ struct ImageMemoryRequirementsInfo2\r
+ {\r
+ ImageMemoryRequirementsInfo2( Image image_ = Image() )\r
+ : image( image_ )\r
+ {\r
+ }\r
+\r
+ ImageMemoryRequirementsInfo2( VkImageMemoryRequirementsInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageMemoryRequirementsInfo2 ) );\r
+ }\r
+\r
+ ImageMemoryRequirementsInfo2& operator=( VkImageMemoryRequirementsInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageMemoryRequirementsInfo2 ) );\r
+ return *this;\r
+ }\r
+ ImageMemoryRequirementsInfo2& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryRequirementsInfo2& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageMemoryRequirementsInfo2&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageMemoryRequirementsInfo2*>(this);\r
+ }\r
+\r
+ bool operator==( ImageMemoryRequirementsInfo2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( image == rhs.image );\r
+ }\r
+\r
+ bool operator!=( ImageMemoryRequirementsInfo2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageMemoryRequirementsInfo2;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Image image;\r
+ };\r
+ static_assert( sizeof( ImageMemoryRequirementsInfo2 ) == sizeof( VkImageMemoryRequirementsInfo2 ), "struct and wrapper have different size!" );\r
+\r
+ using ImageMemoryRequirementsInfo2KHR = ImageMemoryRequirementsInfo2;\r
+\r
+ struct ImageSparseMemoryRequirementsInfo2\r
+ {\r
+ ImageSparseMemoryRequirementsInfo2( Image image_ = Image() )\r
+ : image( image_ )\r
+ {\r
+ }\r
+\r
+ ImageSparseMemoryRequirementsInfo2( VkImageSparseMemoryRequirementsInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSparseMemoryRequirementsInfo2 ) );\r
+ }\r
+\r
+ ImageSparseMemoryRequirementsInfo2& operator=( VkImageSparseMemoryRequirementsInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSparseMemoryRequirementsInfo2 ) );\r
+ return *this;\r
+ }\r
+ ImageSparseMemoryRequirementsInfo2& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSparseMemoryRequirementsInfo2& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageSparseMemoryRequirementsInfo2&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>(this);\r
+ }\r
+\r
+ bool operator==( ImageSparseMemoryRequirementsInfo2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( image == rhs.image );\r
+ }\r
+\r
+ bool operator!=( ImageSparseMemoryRequirementsInfo2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageSparseMemoryRequirementsInfo2;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Image image;\r
+ };\r
+ static_assert( sizeof( ImageSparseMemoryRequirementsInfo2 ) == sizeof( VkImageSparseMemoryRequirementsInfo2 ), "struct and wrapper have different size!" );\r
+\r
+ using ImageSparseMemoryRequirementsInfo2KHR = ImageSparseMemoryRequirementsInfo2;\r
+\r
+ struct MemoryRequirements2\r
+ {\r
+ operator const VkMemoryRequirements2&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryRequirements2*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryRequirements2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memoryRequirements == rhs.memoryRequirements );\r
+ }\r
+\r
+ bool operator!=( MemoryRequirements2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryRequirements2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ MemoryRequirements memoryRequirements;\r
+ };\r
+ static_assert( sizeof( MemoryRequirements2 ) == sizeof( VkMemoryRequirements2 ), "struct and wrapper have different size!" );\r
+\r
+ using MemoryRequirements2KHR = MemoryRequirements2;\r
+\r
+ struct MemoryDedicatedRequirements\r
+ {\r
+ operator const VkMemoryDedicatedRequirements&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryDedicatedRequirements*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryDedicatedRequirements const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( prefersDedicatedAllocation == rhs.prefersDedicatedAllocation )\r
+ && ( requiresDedicatedAllocation == rhs.requiresDedicatedAllocation );\r
+ }\r
+\r
+ bool operator!=( MemoryDedicatedRequirements const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryDedicatedRequirements;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 prefersDedicatedAllocation;\r
+ Bool32 requiresDedicatedAllocation;\r
+ };\r
+ static_assert( sizeof( MemoryDedicatedRequirements ) == sizeof( VkMemoryDedicatedRequirements ), "struct and wrapper have different size!" );\r
+\r
+ using MemoryDedicatedRequirementsKHR = MemoryDedicatedRequirements;\r
+\r
+ struct MemoryDedicatedAllocateInfo\r
+ {\r
+ MemoryDedicatedAllocateInfo( Image image_ = Image(), Buffer buffer_ = Buffer() )\r
+ : image( image_ )\r
+ , buffer( buffer_ )\r
+ {\r
+ }\r
+\r
+ MemoryDedicatedAllocateInfo( VkMemoryDedicatedAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryDedicatedAllocateInfo ) );\r
+ }\r
+\r
+ MemoryDedicatedAllocateInfo& operator=( VkMemoryDedicatedAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryDedicatedAllocateInfo ) );\r
+ return *this;\r
+ }\r
+ MemoryDedicatedAllocateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryDedicatedAllocateInfo& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryDedicatedAllocateInfo& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryDedicatedAllocateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryDedicatedAllocateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryDedicatedAllocateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( image == rhs.image )\r
+ && ( buffer == rhs.buffer );\r
+ }\r
+\r
+ bool operator!=( MemoryDedicatedAllocateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryDedicatedAllocateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Image image;\r
+ Buffer buffer;\r
+ };\r
+ static_assert( sizeof( MemoryDedicatedAllocateInfo ) == sizeof( VkMemoryDedicatedAllocateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using MemoryDedicatedAllocateInfoKHR = MemoryDedicatedAllocateInfo;\r
+\r
+ struct SamplerYcbcrConversionInfo\r
+ {\r
+ SamplerYcbcrConversionInfo( SamplerYcbcrConversion conversion_ = SamplerYcbcrConversion() )\r
+ : conversion( conversion_ )\r
+ {\r
+ }\r
+\r
+ SamplerYcbcrConversionInfo( VkSamplerYcbcrConversionInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerYcbcrConversionInfo ) );\r
+ }\r
+\r
+ SamplerYcbcrConversionInfo& operator=( VkSamplerYcbcrConversionInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerYcbcrConversionInfo ) );\r
+ return *this;\r
+ }\r
+ SamplerYcbcrConversionInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionInfo& setConversion( SamplerYcbcrConversion conversion_ )\r
+ {\r
+ conversion = conversion_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSamplerYcbcrConversionInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSamplerYcbcrConversionInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SamplerYcbcrConversionInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( conversion == rhs.conversion );\r
+ }\r
+\r
+ bool operator!=( SamplerYcbcrConversionInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSamplerYcbcrConversionInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SamplerYcbcrConversion conversion;\r
+ };\r
+ static_assert( sizeof( SamplerYcbcrConversionInfo ) == sizeof( VkSamplerYcbcrConversionInfo ), "struct and wrapper have different size!" );\r
+\r
+ using SamplerYcbcrConversionInfoKHR = SamplerYcbcrConversionInfo;\r
+\r
+ struct PhysicalDeviceSamplerYcbcrConversionFeatures\r
+ {\r
+ PhysicalDeviceSamplerYcbcrConversionFeatures( Bool32 samplerYcbcrConversion_ = 0 )\r
+ : samplerYcbcrConversion( samplerYcbcrConversion_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceSamplerYcbcrConversionFeatures( VkPhysicalDeviceSamplerYcbcrConversionFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceSamplerYcbcrConversionFeatures ) );\r
+ }\r
+\r
+ PhysicalDeviceSamplerYcbcrConversionFeatures& operator=( VkPhysicalDeviceSamplerYcbcrConversionFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceSamplerYcbcrConversionFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceSamplerYcbcrConversionFeatures& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSamplerYcbcrConversionFeatures& setSamplerYcbcrConversion( Bool32 samplerYcbcrConversion_ )\r
+ {\r
+ samplerYcbcrConversion = samplerYcbcrConversion_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceSamplerYcbcrConversionFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSamplerYcbcrConversionFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSamplerYcbcrConversionFeatures const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( samplerYcbcrConversion == rhs.samplerYcbcrConversion );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSamplerYcbcrConversionFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceSamplerYcbcrConversionFeatures;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 samplerYcbcrConversion;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSamplerYcbcrConversionFeatures ) == sizeof( VkPhysicalDeviceSamplerYcbcrConversionFeatures ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceSamplerYcbcrConversionFeaturesKHR = PhysicalDeviceSamplerYcbcrConversionFeatures;\r
+\r
+ struct SamplerYcbcrConversionImageFormatProperties\r
+ {\r
+ operator const VkSamplerYcbcrConversionImageFormatProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkSamplerYcbcrConversionImageFormatProperties*>(this);\r
+ }\r
+\r
+ bool operator==( SamplerYcbcrConversionImageFormatProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( combinedImageSamplerDescriptorCount == rhs.combinedImageSamplerDescriptorCount );\r
+ }\r
+\r
+ bool operator!=( SamplerYcbcrConversionImageFormatProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSamplerYcbcrConversionImageFormatProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t combinedImageSamplerDescriptorCount;\r
+ };\r
+ static_assert( sizeof( SamplerYcbcrConversionImageFormatProperties ) == sizeof( VkSamplerYcbcrConversionImageFormatProperties ), "struct and wrapper have different size!" );\r
+\r
+ using SamplerYcbcrConversionImageFormatPropertiesKHR = SamplerYcbcrConversionImageFormatProperties;\r
+\r
+ struct TextureLODGatherFormatPropertiesAMD\r
+ {\r
+ operator const VkTextureLODGatherFormatPropertiesAMD&() const\r
+ {\r
+ return *reinterpret_cast<const VkTextureLODGatherFormatPropertiesAMD*>(this);\r
+ }\r
+\r
+ bool operator==( TextureLODGatherFormatPropertiesAMD const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( supportsTextureGatherLODBiasAMD == rhs.supportsTextureGatherLODBiasAMD );\r
+ }\r
+\r
+ bool operator!=( TextureLODGatherFormatPropertiesAMD const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eTextureLodGatherFormatPropertiesAMD;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 supportsTextureGatherLODBiasAMD;\r
+ };\r
+ static_assert( sizeof( TextureLODGatherFormatPropertiesAMD ) == sizeof( VkTextureLODGatherFormatPropertiesAMD ), "struct and wrapper have different size!" );\r
+\r
+ struct ProtectedSubmitInfo\r
+ {\r
+ ProtectedSubmitInfo( Bool32 protectedSubmit_ = 0 )\r
+ : protectedSubmit( protectedSubmit_ )\r
+ {\r
+ }\r
+\r
+ ProtectedSubmitInfo( VkProtectedSubmitInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ProtectedSubmitInfo ) );\r
+ }\r
+\r
+ ProtectedSubmitInfo& operator=( VkProtectedSubmitInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ProtectedSubmitInfo ) );\r
+ return *this;\r
+ }\r
+ ProtectedSubmitInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ProtectedSubmitInfo& setProtectedSubmit( Bool32 protectedSubmit_ )\r
+ {\r
+ protectedSubmit = protectedSubmit_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkProtectedSubmitInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkProtectedSubmitInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ProtectedSubmitInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( protectedSubmit == rhs.protectedSubmit );\r
+ }\r
+\r
+ bool operator!=( ProtectedSubmitInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eProtectedSubmitInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 protectedSubmit;\r
+ };\r
+ static_assert( sizeof( ProtectedSubmitInfo ) == sizeof( VkProtectedSubmitInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceProtectedMemoryFeatures\r
+ {\r
+ PhysicalDeviceProtectedMemoryFeatures( Bool32 protectedMemory_ = 0 )\r
+ : protectedMemory( protectedMemory_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceProtectedMemoryFeatures( VkPhysicalDeviceProtectedMemoryFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceProtectedMemoryFeatures ) );\r
+ }\r
+\r
+ PhysicalDeviceProtectedMemoryFeatures& operator=( VkPhysicalDeviceProtectedMemoryFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceProtectedMemoryFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceProtectedMemoryFeatures& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceProtectedMemoryFeatures& setProtectedMemory( Bool32 protectedMemory_ )\r
+ {\r
+ protectedMemory = protectedMemory_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceProtectedMemoryFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceProtectedMemoryFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceProtectedMemoryFeatures const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( protectedMemory == rhs.protectedMemory );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceProtectedMemoryFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceProtectedMemoryFeatures;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 protectedMemory;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceProtectedMemoryFeatures ) == sizeof( VkPhysicalDeviceProtectedMemoryFeatures ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceProtectedMemoryProperties\r
+ {\r
+ PhysicalDeviceProtectedMemoryProperties( Bool32 protectedNoFault_ = 0 )\r
+ : protectedNoFault( protectedNoFault_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceProtectedMemoryProperties( VkPhysicalDeviceProtectedMemoryProperties const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceProtectedMemoryProperties ) );\r
+ }\r
+\r
+ PhysicalDeviceProtectedMemoryProperties& operator=( VkPhysicalDeviceProtectedMemoryProperties const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceProtectedMemoryProperties ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceProtectedMemoryProperties& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceProtectedMemoryProperties& setProtectedNoFault( Bool32 protectedNoFault_ )\r
+ {\r
+ protectedNoFault = protectedNoFault_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceProtectedMemoryProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceProtectedMemoryProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceProtectedMemoryProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( protectedNoFault == rhs.protectedNoFault );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceProtectedMemoryProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceProtectedMemoryProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 protectedNoFault;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceProtectedMemoryProperties ) == sizeof( VkPhysicalDeviceProtectedMemoryProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineCoverageToColorStateCreateInfoNV\r
+ {\r
+ PipelineCoverageToColorStateCreateInfoNV( PipelineCoverageToColorStateCreateFlagsNV flags_ = PipelineCoverageToColorStateCreateFlagsNV(), Bool32 coverageToColorEnable_ = 0, uint32_t coverageToColorLocation_ = 0 )\r
+ : flags( flags_ )\r
+ , coverageToColorEnable( coverageToColorEnable_ )\r
+ , coverageToColorLocation( coverageToColorLocation_ )\r
+ {\r
+ }\r
+\r
+ PipelineCoverageToColorStateCreateInfoNV( VkPipelineCoverageToColorStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineCoverageToColorStateCreateInfoNV ) );\r
+ }\r
+\r
+ PipelineCoverageToColorStateCreateInfoNV& operator=( VkPipelineCoverageToColorStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineCoverageToColorStateCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ PipelineCoverageToColorStateCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageToColorStateCreateInfoNV& setFlags( PipelineCoverageToColorStateCreateFlagsNV flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageToColorStateCreateInfoNV& setCoverageToColorEnable( Bool32 coverageToColorEnable_ )\r
+ {\r
+ coverageToColorEnable = coverageToColorEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageToColorStateCreateInfoNV& setCoverageToColorLocation( uint32_t coverageToColorLocation_ )\r
+ {\r
+ coverageToColorLocation = coverageToColorLocation_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineCoverageToColorStateCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineCoverageToColorStateCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineCoverageToColorStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( coverageToColorEnable == rhs.coverageToColorEnable )\r
+ && ( coverageToColorLocation == rhs.coverageToColorLocation );\r
+ }\r
+\r
+ bool operator!=( PipelineCoverageToColorStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineCoverageToColorStateCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineCoverageToColorStateCreateFlagsNV flags;\r
+ Bool32 coverageToColorEnable;\r
+ uint32_t coverageToColorLocation;\r
+ };\r
+ static_assert( sizeof( PipelineCoverageToColorStateCreateInfoNV ) == sizeof( VkPipelineCoverageToColorStateCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceSamplerFilterMinmaxPropertiesEXT\r
+ {\r
+ operator const VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSamplerFilterMinmaxPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( filterMinmaxSingleComponentFormats == rhs.filterMinmaxSingleComponentFormats )\r
+ && ( filterMinmaxImageComponentMapping == rhs.filterMinmaxImageComponentMapping );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSamplerFilterMinmaxPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceSamplerFilterMinmaxPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 filterMinmaxSingleComponentFormats;\r
+ Bool32 filterMinmaxImageComponentMapping;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSamplerFilterMinmaxPropertiesEXT ) == sizeof( VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct MultisamplePropertiesEXT\r
+ {\r
+ operator const VkMultisamplePropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkMultisamplePropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( MultisamplePropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxSampleLocationGridSize == rhs.maxSampleLocationGridSize );\r
+ }\r
+\r
+ bool operator!=( MultisamplePropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMultisamplePropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Extent2D maxSampleLocationGridSize;\r
+ };\r
+ static_assert( sizeof( MultisamplePropertiesEXT ) == sizeof( VkMultisamplePropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceBlendOperationAdvancedFeaturesEXT\r
+ {\r
+ PhysicalDeviceBlendOperationAdvancedFeaturesEXT( Bool32 advancedBlendCoherentOperations_ = 0 )\r
+ : advancedBlendCoherentOperations( advancedBlendCoherentOperations_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceBlendOperationAdvancedFeaturesEXT( VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceBlendOperationAdvancedFeaturesEXT ) );\r
+ }\r
+\r
+ PhysicalDeviceBlendOperationAdvancedFeaturesEXT& operator=( VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceBlendOperationAdvancedFeaturesEXT ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceBlendOperationAdvancedFeaturesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceBlendOperationAdvancedFeaturesEXT& setAdvancedBlendCoherentOperations( Bool32 advancedBlendCoherentOperations_ )\r
+ {\r
+ advancedBlendCoherentOperations = advancedBlendCoherentOperations_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceBlendOperationAdvancedFeaturesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( advancedBlendCoherentOperations == rhs.advancedBlendCoherentOperations );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceBlendOperationAdvancedFeaturesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceBlendOperationAdvancedFeaturesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 advancedBlendCoherentOperations;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceBlendOperationAdvancedFeaturesEXT ) == sizeof( VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceBlendOperationAdvancedPropertiesEXT\r
+ {\r
+ operator const VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceBlendOperationAdvancedPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( advancedBlendMaxColorAttachments == rhs.advancedBlendMaxColorAttachments )\r
+ && ( advancedBlendIndependentBlend == rhs.advancedBlendIndependentBlend )\r
+ && ( advancedBlendNonPremultipliedSrcColor == rhs.advancedBlendNonPremultipliedSrcColor )\r
+ && ( advancedBlendNonPremultipliedDstColor == rhs.advancedBlendNonPremultipliedDstColor )\r
+ && ( advancedBlendCorrelatedOverlap == rhs.advancedBlendCorrelatedOverlap )\r
+ && ( advancedBlendAllOperations == rhs.advancedBlendAllOperations );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceBlendOperationAdvancedPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceBlendOperationAdvancedPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t advancedBlendMaxColorAttachments;\r
+ Bool32 advancedBlendIndependentBlend;\r
+ Bool32 advancedBlendNonPremultipliedSrcColor;\r
+ Bool32 advancedBlendNonPremultipliedDstColor;\r
+ Bool32 advancedBlendCorrelatedOverlap;\r
+ Bool32 advancedBlendAllOperations;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceBlendOperationAdvancedPropertiesEXT ) == sizeof( VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageFormatListCreateInfoKHR\r
+ {\r
+ ImageFormatListCreateInfoKHR( uint32_t viewFormatCount_ = 0, const Format* pViewFormats_ = nullptr )\r
+ : viewFormatCount( viewFormatCount_ )\r
+ , pViewFormats( pViewFormats_ )\r
+ {\r
+ }\r
+\r
+ ImageFormatListCreateInfoKHR( VkImageFormatListCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageFormatListCreateInfoKHR ) );\r
+ }\r
+\r
+ ImageFormatListCreateInfoKHR& operator=( VkImageFormatListCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageFormatListCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImageFormatListCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageFormatListCreateInfoKHR& setViewFormatCount( uint32_t viewFormatCount_ )\r
+ {\r
+ viewFormatCount = viewFormatCount_;\r
+ return *this;\r
+ }\r
+\r
+ ImageFormatListCreateInfoKHR& setPViewFormats( const Format* pViewFormats_ )\r
+ {\r
+ pViewFormats = pViewFormats_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageFormatListCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageFormatListCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImageFormatListCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( viewFormatCount == rhs.viewFormatCount )\r
+ && ( pViewFormats == rhs.pViewFormats );\r
+ }\r
+\r
+ bool operator!=( ImageFormatListCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageFormatListCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t viewFormatCount;\r
+ const Format* pViewFormats;\r
+ };\r
+ static_assert( sizeof( ImageFormatListCreateInfoKHR ) == sizeof( VkImageFormatListCreateInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct ValidationCacheCreateInfoEXT\r
+ {\r
+ ValidationCacheCreateInfoEXT( ValidationCacheCreateFlagsEXT flags_ = ValidationCacheCreateFlagsEXT(), size_t initialDataSize_ = 0, const void* pInitialData_ = nullptr )\r
+ : flags( flags_ )\r
+ , initialDataSize( initialDataSize_ )\r
+ , pInitialData( pInitialData_ )\r
+ {\r
+ }\r
+\r
+ ValidationCacheCreateInfoEXT( VkValidationCacheCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ValidationCacheCreateInfoEXT ) );\r
+ }\r
+\r
+ ValidationCacheCreateInfoEXT& operator=( VkValidationCacheCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ValidationCacheCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ ValidationCacheCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ValidationCacheCreateInfoEXT& setFlags( ValidationCacheCreateFlagsEXT flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ValidationCacheCreateInfoEXT& setInitialDataSize( size_t initialDataSize_ )\r
+ {\r
+ initialDataSize = initialDataSize_;\r
+ return *this;\r
+ }\r
+\r
+ ValidationCacheCreateInfoEXT& setPInitialData( const void* pInitialData_ )\r
+ {\r
+ pInitialData = pInitialData_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkValidationCacheCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkValidationCacheCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( ValidationCacheCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( initialDataSize == rhs.initialDataSize )\r
+ && ( pInitialData == rhs.pInitialData );\r
+ }\r
+\r
+ bool operator!=( ValidationCacheCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eValidationCacheCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ValidationCacheCreateFlagsEXT flags;\r
+ size_t initialDataSize;\r
+ const void* pInitialData;\r
+ };\r
+ static_assert( sizeof( ValidationCacheCreateInfoEXT ) == sizeof( VkValidationCacheCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct ShaderModuleValidationCacheCreateInfoEXT\r
+ {\r
+ ShaderModuleValidationCacheCreateInfoEXT( ValidationCacheEXT validationCache_ = ValidationCacheEXT() )\r
+ : validationCache( validationCache_ )\r
+ {\r
+ }\r
+\r
+ ShaderModuleValidationCacheCreateInfoEXT( VkShaderModuleValidationCacheCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ShaderModuleValidationCacheCreateInfoEXT ) );\r
+ }\r
+\r
+ ShaderModuleValidationCacheCreateInfoEXT& operator=( VkShaderModuleValidationCacheCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ShaderModuleValidationCacheCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ ShaderModuleValidationCacheCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ShaderModuleValidationCacheCreateInfoEXT& setValidationCache( ValidationCacheEXT validationCache_ )\r
+ {\r
+ validationCache = validationCache_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkShaderModuleValidationCacheCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkShaderModuleValidationCacheCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( ShaderModuleValidationCacheCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( validationCache == rhs.validationCache );\r
+ }\r
+\r
+ bool operator!=( ShaderModuleValidationCacheCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eShaderModuleValidationCacheCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ValidationCacheEXT validationCache;\r
+ };\r
+ static_assert( sizeof( ShaderModuleValidationCacheCreateInfoEXT ) == sizeof( VkShaderModuleValidationCacheCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceMaintenance3Properties\r
+ {\r
+ operator const VkPhysicalDeviceMaintenance3Properties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceMaintenance3Properties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceMaintenance3Properties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxPerSetDescriptors == rhs.maxPerSetDescriptors )\r
+ && ( maxMemoryAllocationSize == rhs.maxMemoryAllocationSize );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceMaintenance3Properties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceMaintenance3Properties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxPerSetDescriptors;\r
+ DeviceSize maxMemoryAllocationSize;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceMaintenance3Properties ) == sizeof( VkPhysicalDeviceMaintenance3Properties ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceMaintenance3PropertiesKHR = PhysicalDeviceMaintenance3Properties;\r
+\r
+ struct DescriptorSetLayoutSupport\r
+ {\r
+ operator const VkDescriptorSetLayoutSupport&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetLayoutSupport*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetLayoutSupport const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( supported == rhs.supported );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetLayoutSupport const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorSetLayoutSupport;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 supported;\r
+ };\r
+ static_assert( sizeof( DescriptorSetLayoutSupport ) == sizeof( VkDescriptorSetLayoutSupport ), "struct and wrapper have different size!" );\r
+\r
+ using DescriptorSetLayoutSupportKHR = DescriptorSetLayoutSupport;\r
+\r
+ struct PhysicalDeviceShaderDrawParameterFeatures\r
+ {\r
+ PhysicalDeviceShaderDrawParameterFeatures( Bool32 shaderDrawParameters_ = 0 )\r
+ : shaderDrawParameters( shaderDrawParameters_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceShaderDrawParameterFeatures( VkPhysicalDeviceShaderDrawParameterFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceShaderDrawParameterFeatures ) );\r
+ }\r
+\r
+ PhysicalDeviceShaderDrawParameterFeatures& operator=( VkPhysicalDeviceShaderDrawParameterFeatures const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceShaderDrawParameterFeatures ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceShaderDrawParameterFeatures& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceShaderDrawParameterFeatures& setShaderDrawParameters( Bool32 shaderDrawParameters_ )\r
+ {\r
+ shaderDrawParameters = shaderDrawParameters_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceShaderDrawParameterFeatures&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceShaderDrawParameterFeatures*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceShaderDrawParameterFeatures const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( shaderDrawParameters == rhs.shaderDrawParameters );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceShaderDrawParameterFeatures const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceShaderDrawParameterFeatures;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 shaderDrawParameters;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceShaderDrawParameterFeatures ) == sizeof( VkPhysicalDeviceShaderDrawParameterFeatures ), "struct and wrapper have different size!" );\r
+\r
+ struct DebugUtilsLabelEXT\r
+ {\r
+ DebugUtilsLabelEXT( const char* pLabelName_ = nullptr, std::array<float,4> const& color_ = { { 0, 0, 0, 0 } } )\r
+ : pLabelName( pLabelName_ )\r
+ {\r
+ memcpy( &color, color_.data(), 4 * sizeof( float ) );\r
+ }\r
+\r
+ DebugUtilsLabelEXT( VkDebugUtilsLabelEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsLabelEXT ) );\r
+ }\r
+\r
+ DebugUtilsLabelEXT& operator=( VkDebugUtilsLabelEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsLabelEXT ) );\r
+ return *this;\r
+ }\r
+ DebugUtilsLabelEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsLabelEXT& setPLabelName( const char* pLabelName_ )\r
+ {\r
+ pLabelName = pLabelName_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsLabelEXT& setColor( std::array<float,4> color_ )\r
+ {\r
+ memcpy( &color, color_.data(), 4 * sizeof( float ) );\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugUtilsLabelEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugUtilsLabelEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugUtilsLabelEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pLabelName == rhs.pLabelName )\r
+ && ( memcmp( color, rhs.color, 4 * sizeof( float ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( DebugUtilsLabelEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugUtilsLabelEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ const char* pLabelName;\r
+ float color[4];\r
+ };\r
+ static_assert( sizeof( DebugUtilsLabelEXT ) == sizeof( VkDebugUtilsLabelEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct MemoryHostPointerPropertiesEXT\r
+ {\r
+ MemoryHostPointerPropertiesEXT( uint32_t memoryTypeBits_ = 0 )\r
+ : memoryTypeBits( memoryTypeBits_ )\r
+ {\r
+ }\r
+\r
+ MemoryHostPointerPropertiesEXT( VkMemoryHostPointerPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryHostPointerPropertiesEXT ) );\r
+ }\r
+\r
+ MemoryHostPointerPropertiesEXT& operator=( VkMemoryHostPointerPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryHostPointerPropertiesEXT ) );\r
+ return *this;\r
+ }\r
+ MemoryHostPointerPropertiesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryHostPointerPropertiesEXT& setMemoryTypeBits( uint32_t memoryTypeBits_ )\r
+ {\r
+ memoryTypeBits = memoryTypeBits_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryHostPointerPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryHostPointerPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryHostPointerPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memoryTypeBits == rhs.memoryTypeBits );\r
+ }\r
+\r
+ bool operator!=( MemoryHostPointerPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryHostPointerPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t memoryTypeBits;\r
+ };\r
+ static_assert( sizeof( MemoryHostPointerPropertiesEXT ) == sizeof( VkMemoryHostPointerPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceExternalMemoryHostPropertiesEXT\r
+ {\r
+ PhysicalDeviceExternalMemoryHostPropertiesEXT( DeviceSize minImportedHostPointerAlignment_ = 0 )\r
+ : minImportedHostPointerAlignment( minImportedHostPointerAlignment_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceExternalMemoryHostPropertiesEXT( VkPhysicalDeviceExternalMemoryHostPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalMemoryHostPropertiesEXT ) );\r
+ }\r
+\r
+ PhysicalDeviceExternalMemoryHostPropertiesEXT& operator=( VkPhysicalDeviceExternalMemoryHostPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalMemoryHostPropertiesEXT ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceExternalMemoryHostPropertiesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalMemoryHostPropertiesEXT& setMinImportedHostPointerAlignment( DeviceSize minImportedHostPointerAlignment_ )\r
+ {\r
+ minImportedHostPointerAlignment = minImportedHostPointerAlignment_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceExternalMemoryHostPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceExternalMemoryHostPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceExternalMemoryHostPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( minImportedHostPointerAlignment == rhs.minImportedHostPointerAlignment );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceExternalMemoryHostPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceExternalMemoryHostPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ DeviceSize minImportedHostPointerAlignment;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceExternalMemoryHostPropertiesEXT ) == sizeof( VkPhysicalDeviceExternalMemoryHostPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceConservativeRasterizationPropertiesEXT\r
+ {\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT( float primitiveOverestimationSize_ = 0, float maxExtraPrimitiveOverestimationSize_ = 0, float extraPrimitiveOverestimationSizeGranularity_ = 0, Bool32 primitiveUnderestimation_ = 0, Bool32 conservativePointAndLineRasterization_ = 0, Bool32 degenerateTrianglesRasterized_ = 0, Bool32 degenerateLinesRasterized_ = 0, Bool32 fullyCoveredFragmentShaderInputVariable_ = 0, Bool32 conservativeRasterizationPostDepthCoverage_ = 0 )\r
+ : primitiveOverestimationSize( primitiveOverestimationSize_ )\r
+ , maxExtraPrimitiveOverestimationSize( maxExtraPrimitiveOverestimationSize_ )\r
+ , extraPrimitiveOverestimationSizeGranularity( extraPrimitiveOverestimationSizeGranularity_ )\r
+ , primitiveUnderestimation( primitiveUnderestimation_ )\r
+ , conservativePointAndLineRasterization( conservativePointAndLineRasterization_ )\r
+ , degenerateTrianglesRasterized( degenerateTrianglesRasterized_ )\r
+ , degenerateLinesRasterized( degenerateLinesRasterized_ )\r
+ , fullyCoveredFragmentShaderInputVariable( fullyCoveredFragmentShaderInputVariable_ )\r
+ , conservativeRasterizationPostDepthCoverage( conservativeRasterizationPostDepthCoverage_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT( VkPhysicalDeviceConservativeRasterizationPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceConservativeRasterizationPropertiesEXT ) );\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& operator=( VkPhysicalDeviceConservativeRasterizationPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceConservativeRasterizationPropertiesEXT ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setPrimitiveOverestimationSize( float primitiveOverestimationSize_ )\r
+ {\r
+ primitiveOverestimationSize = primitiveOverestimationSize_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setMaxExtraPrimitiveOverestimationSize( float maxExtraPrimitiveOverestimationSize_ )\r
+ {\r
+ maxExtraPrimitiveOverestimationSize = maxExtraPrimitiveOverestimationSize_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setExtraPrimitiveOverestimationSizeGranularity( float extraPrimitiveOverestimationSizeGranularity_ )\r
+ {\r
+ extraPrimitiveOverestimationSizeGranularity = extraPrimitiveOverestimationSizeGranularity_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setPrimitiveUnderestimation( Bool32 primitiveUnderestimation_ )\r
+ {\r
+ primitiveUnderestimation = primitiveUnderestimation_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setConservativePointAndLineRasterization( Bool32 conservativePointAndLineRasterization_ )\r
+ {\r
+ conservativePointAndLineRasterization = conservativePointAndLineRasterization_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setDegenerateTrianglesRasterized( Bool32 degenerateTrianglesRasterized_ )\r
+ {\r
+ degenerateTrianglesRasterized = degenerateTrianglesRasterized_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setDegenerateLinesRasterized( Bool32 degenerateLinesRasterized_ )\r
+ {\r
+ degenerateLinesRasterized = degenerateLinesRasterized_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setFullyCoveredFragmentShaderInputVariable( Bool32 fullyCoveredFragmentShaderInputVariable_ )\r
+ {\r
+ fullyCoveredFragmentShaderInputVariable = fullyCoveredFragmentShaderInputVariable_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceConservativeRasterizationPropertiesEXT& setConservativeRasterizationPostDepthCoverage( Bool32 conservativeRasterizationPostDepthCoverage_ )\r
+ {\r
+ conservativeRasterizationPostDepthCoverage = conservativeRasterizationPostDepthCoverage_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceConservativeRasterizationPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceConservativeRasterizationPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceConservativeRasterizationPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( primitiveOverestimationSize == rhs.primitiveOverestimationSize )\r
+ && ( maxExtraPrimitiveOverestimationSize == rhs.maxExtraPrimitiveOverestimationSize )\r
+ && ( extraPrimitiveOverestimationSizeGranularity == rhs.extraPrimitiveOverestimationSizeGranularity )\r
+ && ( primitiveUnderestimation == rhs.primitiveUnderestimation )\r
+ && ( conservativePointAndLineRasterization == rhs.conservativePointAndLineRasterization )\r
+ && ( degenerateTrianglesRasterized == rhs.degenerateTrianglesRasterized )\r
+ && ( degenerateLinesRasterized == rhs.degenerateLinesRasterized )\r
+ && ( fullyCoveredFragmentShaderInputVariable == rhs.fullyCoveredFragmentShaderInputVariable )\r
+ && ( conservativeRasterizationPostDepthCoverage == rhs.conservativeRasterizationPostDepthCoverage );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceConservativeRasterizationPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceConservativeRasterizationPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ float primitiveOverestimationSize;\r
+ float maxExtraPrimitiveOverestimationSize;\r
+ float extraPrimitiveOverestimationSizeGranularity;\r
+ Bool32 primitiveUnderestimation;\r
+ Bool32 conservativePointAndLineRasterization;\r
+ Bool32 degenerateTrianglesRasterized;\r
+ Bool32 degenerateLinesRasterized;\r
+ Bool32 fullyCoveredFragmentShaderInputVariable;\r
+ Bool32 conservativeRasterizationPostDepthCoverage;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceConservativeRasterizationPropertiesEXT ) == sizeof( VkPhysicalDeviceConservativeRasterizationPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceShaderCorePropertiesAMD\r
+ {\r
+ operator const VkPhysicalDeviceShaderCorePropertiesAMD&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceShaderCorePropertiesAMD*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceShaderCorePropertiesAMD const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( shaderEngineCount == rhs.shaderEngineCount )\r
+ && ( shaderArraysPerEngineCount == rhs.shaderArraysPerEngineCount )\r
+ && ( computeUnitsPerShaderArray == rhs.computeUnitsPerShaderArray )\r
+ && ( simdPerComputeUnit == rhs.simdPerComputeUnit )\r
+ && ( wavefrontsPerSimd == rhs.wavefrontsPerSimd )\r
+ && ( wavefrontSize == rhs.wavefrontSize )\r
+ && ( sgprsPerSimd == rhs.sgprsPerSimd )\r
+ && ( minSgprAllocation == rhs.minSgprAllocation )\r
+ && ( maxSgprAllocation == rhs.maxSgprAllocation )\r
+ && ( sgprAllocationGranularity == rhs.sgprAllocationGranularity )\r
+ && ( vgprsPerSimd == rhs.vgprsPerSimd )\r
+ && ( minVgprAllocation == rhs.minVgprAllocation )\r
+ && ( maxVgprAllocation == rhs.maxVgprAllocation )\r
+ && ( vgprAllocationGranularity == rhs.vgprAllocationGranularity );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceShaderCorePropertiesAMD const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceShaderCorePropertiesAMD;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t shaderEngineCount;\r
+ uint32_t shaderArraysPerEngineCount;\r
+ uint32_t computeUnitsPerShaderArray;\r
+ uint32_t simdPerComputeUnit;\r
+ uint32_t wavefrontsPerSimd;\r
+ uint32_t wavefrontSize;\r
+ uint32_t sgprsPerSimd;\r
+ uint32_t minSgprAllocation;\r
+ uint32_t maxSgprAllocation;\r
+ uint32_t sgprAllocationGranularity;\r
+ uint32_t vgprsPerSimd;\r
+ uint32_t minVgprAllocation;\r
+ uint32_t maxVgprAllocation;\r
+ uint32_t vgprAllocationGranularity;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceShaderCorePropertiesAMD ) == sizeof( VkPhysicalDeviceShaderCorePropertiesAMD ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceDescriptorIndexingFeaturesEXT\r
+ {\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT( Bool32 shaderInputAttachmentArrayDynamicIndexing_ = 0, Bool32 shaderUniformTexelBufferArrayDynamicIndexing_ = 0, Bool32 shaderStorageTexelBufferArrayDynamicIndexing_ = 0, Bool32 shaderUniformBufferArrayNonUniformIndexing_ = 0, Bool32 shaderSampledImageArrayNonUniformIndexing_ = 0, Bool32 shaderStorageBufferArrayNonUniformIndexing_ = 0, Bool32 shaderStorageImageArrayNonUniformIndexing_ = 0, Bool32 shaderInputAttachmentArrayNonUniformIndexing_ = 0, Bool32 shaderUniformTexelBufferArrayNonUniformIndexing_ = 0, Bool32 shaderStorageTexelBufferArrayNonUniformIndexing_ = 0, Bool32 descriptorBindingUniformBufferUpdateAfterBind_ = 0, Bool32 descriptorBindingSampledImageUpdateAfterBind_ = 0, Bool32 descriptorBindingStorageImageUpdateAfterBind_ = 0, Bool32 descriptorBindingStorageBufferUpdateAfterBind_ = 0, Bool32 descriptorBindingUniformTexelBufferUpdateAfterBind_ = 0, Bool32 descriptorBindingStorageTexelBufferUpdateAfterBind_ = 0, Bool32 descriptorBindingUpdateUnusedWhilePending_ = 0, Bool32 descriptorBindingPartiallyBound_ = 0, Bool32 descriptorBindingVariableDescriptorCount_ = 0, Bool32 runtimeDescriptorArray_ = 0 )\r
+ : shaderInputAttachmentArrayDynamicIndexing( shaderInputAttachmentArrayDynamicIndexing_ )\r
+ , shaderUniformTexelBufferArrayDynamicIndexing( shaderUniformTexelBufferArrayDynamicIndexing_ )\r
+ , shaderStorageTexelBufferArrayDynamicIndexing( shaderStorageTexelBufferArrayDynamicIndexing_ )\r
+ , shaderUniformBufferArrayNonUniformIndexing( shaderUniformBufferArrayNonUniformIndexing_ )\r
+ , shaderSampledImageArrayNonUniformIndexing( shaderSampledImageArrayNonUniformIndexing_ )\r
+ , shaderStorageBufferArrayNonUniformIndexing( shaderStorageBufferArrayNonUniformIndexing_ )\r
+ , shaderStorageImageArrayNonUniformIndexing( shaderStorageImageArrayNonUniformIndexing_ )\r
+ , shaderInputAttachmentArrayNonUniformIndexing( shaderInputAttachmentArrayNonUniformIndexing_ )\r
+ , shaderUniformTexelBufferArrayNonUniformIndexing( shaderUniformTexelBufferArrayNonUniformIndexing_ )\r
+ , shaderStorageTexelBufferArrayNonUniformIndexing( shaderStorageTexelBufferArrayNonUniformIndexing_ )\r
+ , descriptorBindingUniformBufferUpdateAfterBind( descriptorBindingUniformBufferUpdateAfterBind_ )\r
+ , descriptorBindingSampledImageUpdateAfterBind( descriptorBindingSampledImageUpdateAfterBind_ )\r
+ , descriptorBindingStorageImageUpdateAfterBind( descriptorBindingStorageImageUpdateAfterBind_ )\r
+ , descriptorBindingStorageBufferUpdateAfterBind( descriptorBindingStorageBufferUpdateAfterBind_ )\r
+ , descriptorBindingUniformTexelBufferUpdateAfterBind( descriptorBindingUniformTexelBufferUpdateAfterBind_ )\r
+ , descriptorBindingStorageTexelBufferUpdateAfterBind( descriptorBindingStorageTexelBufferUpdateAfterBind_ )\r
+ , descriptorBindingUpdateUnusedWhilePending( descriptorBindingUpdateUnusedWhilePending_ )\r
+ , descriptorBindingPartiallyBound( descriptorBindingPartiallyBound_ )\r
+ , descriptorBindingVariableDescriptorCount( descriptorBindingVariableDescriptorCount_ )\r
+ , runtimeDescriptorArray( runtimeDescriptorArray_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT( VkPhysicalDeviceDescriptorIndexingFeaturesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceDescriptorIndexingFeaturesEXT ) );\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& operator=( VkPhysicalDeviceDescriptorIndexingFeaturesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceDescriptorIndexingFeaturesEXT ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderInputAttachmentArrayDynamicIndexing( Bool32 shaderInputAttachmentArrayDynamicIndexing_ )\r
+ {\r
+ shaderInputAttachmentArrayDynamicIndexing = shaderInputAttachmentArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderUniformTexelBufferArrayDynamicIndexing( Bool32 shaderUniformTexelBufferArrayDynamicIndexing_ )\r
+ {\r
+ shaderUniformTexelBufferArrayDynamicIndexing = shaderUniformTexelBufferArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderStorageTexelBufferArrayDynamicIndexing( Bool32 shaderStorageTexelBufferArrayDynamicIndexing_ )\r
+ {\r
+ shaderStorageTexelBufferArrayDynamicIndexing = shaderStorageTexelBufferArrayDynamicIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderUniformBufferArrayNonUniformIndexing( Bool32 shaderUniformBufferArrayNonUniformIndexing_ )\r
+ {\r
+ shaderUniformBufferArrayNonUniformIndexing = shaderUniformBufferArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderSampledImageArrayNonUniformIndexing( Bool32 shaderSampledImageArrayNonUniformIndexing_ )\r
+ {\r
+ shaderSampledImageArrayNonUniformIndexing = shaderSampledImageArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderStorageBufferArrayNonUniformIndexing( Bool32 shaderStorageBufferArrayNonUniformIndexing_ )\r
+ {\r
+ shaderStorageBufferArrayNonUniformIndexing = shaderStorageBufferArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderStorageImageArrayNonUniformIndexing( Bool32 shaderStorageImageArrayNonUniformIndexing_ )\r
+ {\r
+ shaderStorageImageArrayNonUniformIndexing = shaderStorageImageArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderInputAttachmentArrayNonUniformIndexing( Bool32 shaderInputAttachmentArrayNonUniformIndexing_ )\r
+ {\r
+ shaderInputAttachmentArrayNonUniformIndexing = shaderInputAttachmentArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderUniformTexelBufferArrayNonUniformIndexing( Bool32 shaderUniformTexelBufferArrayNonUniformIndexing_ )\r
+ {\r
+ shaderUniformTexelBufferArrayNonUniformIndexing = shaderUniformTexelBufferArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setShaderStorageTexelBufferArrayNonUniformIndexing( Bool32 shaderStorageTexelBufferArrayNonUniformIndexing_ )\r
+ {\r
+ shaderStorageTexelBufferArrayNonUniformIndexing = shaderStorageTexelBufferArrayNonUniformIndexing_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingUniformBufferUpdateAfterBind( Bool32 descriptorBindingUniformBufferUpdateAfterBind_ )\r
+ {\r
+ descriptorBindingUniformBufferUpdateAfterBind = descriptorBindingUniformBufferUpdateAfterBind_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingSampledImageUpdateAfterBind( Bool32 descriptorBindingSampledImageUpdateAfterBind_ )\r
+ {\r
+ descriptorBindingSampledImageUpdateAfterBind = descriptorBindingSampledImageUpdateAfterBind_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingStorageImageUpdateAfterBind( Bool32 descriptorBindingStorageImageUpdateAfterBind_ )\r
+ {\r
+ descriptorBindingStorageImageUpdateAfterBind = descriptorBindingStorageImageUpdateAfterBind_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingStorageBufferUpdateAfterBind( Bool32 descriptorBindingStorageBufferUpdateAfterBind_ )\r
+ {\r
+ descriptorBindingStorageBufferUpdateAfterBind = descriptorBindingStorageBufferUpdateAfterBind_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingUniformTexelBufferUpdateAfterBind( Bool32 descriptorBindingUniformTexelBufferUpdateAfterBind_ )\r
+ {\r
+ descriptorBindingUniformTexelBufferUpdateAfterBind = descriptorBindingUniformTexelBufferUpdateAfterBind_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingStorageTexelBufferUpdateAfterBind( Bool32 descriptorBindingStorageTexelBufferUpdateAfterBind_ )\r
+ {\r
+ descriptorBindingStorageTexelBufferUpdateAfterBind = descriptorBindingStorageTexelBufferUpdateAfterBind_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingUpdateUnusedWhilePending( Bool32 descriptorBindingUpdateUnusedWhilePending_ )\r
+ {\r
+ descriptorBindingUpdateUnusedWhilePending = descriptorBindingUpdateUnusedWhilePending_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingPartiallyBound( Bool32 descriptorBindingPartiallyBound_ )\r
+ {\r
+ descriptorBindingPartiallyBound = descriptorBindingPartiallyBound_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setDescriptorBindingVariableDescriptorCount( Bool32 descriptorBindingVariableDescriptorCount_ )\r
+ {\r
+ descriptorBindingVariableDescriptorCount = descriptorBindingVariableDescriptorCount_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceDescriptorIndexingFeaturesEXT& setRuntimeDescriptorArray( Bool32 runtimeDescriptorArray_ )\r
+ {\r
+ runtimeDescriptorArray = runtimeDescriptorArray_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceDescriptorIndexingFeaturesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceDescriptorIndexingFeaturesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceDescriptorIndexingFeaturesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( shaderInputAttachmentArrayDynamicIndexing == rhs.shaderInputAttachmentArrayDynamicIndexing )\r
+ && ( shaderUniformTexelBufferArrayDynamicIndexing == rhs.shaderUniformTexelBufferArrayDynamicIndexing )\r
+ && ( shaderStorageTexelBufferArrayDynamicIndexing == rhs.shaderStorageTexelBufferArrayDynamicIndexing )\r
+ && ( shaderUniformBufferArrayNonUniformIndexing == rhs.shaderUniformBufferArrayNonUniformIndexing )\r
+ && ( shaderSampledImageArrayNonUniformIndexing == rhs.shaderSampledImageArrayNonUniformIndexing )\r
+ && ( shaderStorageBufferArrayNonUniformIndexing == rhs.shaderStorageBufferArrayNonUniformIndexing )\r
+ && ( shaderStorageImageArrayNonUniformIndexing == rhs.shaderStorageImageArrayNonUniformIndexing )\r
+ && ( shaderInputAttachmentArrayNonUniformIndexing == rhs.shaderInputAttachmentArrayNonUniformIndexing )\r
+ && ( shaderUniformTexelBufferArrayNonUniformIndexing == rhs.shaderUniformTexelBufferArrayNonUniformIndexing )\r
+ && ( shaderStorageTexelBufferArrayNonUniformIndexing == rhs.shaderStorageTexelBufferArrayNonUniformIndexing )\r
+ && ( descriptorBindingUniformBufferUpdateAfterBind == rhs.descriptorBindingUniformBufferUpdateAfterBind )\r
+ && ( descriptorBindingSampledImageUpdateAfterBind == rhs.descriptorBindingSampledImageUpdateAfterBind )\r
+ && ( descriptorBindingStorageImageUpdateAfterBind == rhs.descriptorBindingStorageImageUpdateAfterBind )\r
+ && ( descriptorBindingStorageBufferUpdateAfterBind == rhs.descriptorBindingStorageBufferUpdateAfterBind )\r
+ && ( descriptorBindingUniformTexelBufferUpdateAfterBind == rhs.descriptorBindingUniformTexelBufferUpdateAfterBind )\r
+ && ( descriptorBindingStorageTexelBufferUpdateAfterBind == rhs.descriptorBindingStorageTexelBufferUpdateAfterBind )\r
+ && ( descriptorBindingUpdateUnusedWhilePending == rhs.descriptorBindingUpdateUnusedWhilePending )\r
+ && ( descriptorBindingPartiallyBound == rhs.descriptorBindingPartiallyBound )\r
+ && ( descriptorBindingVariableDescriptorCount == rhs.descriptorBindingVariableDescriptorCount )\r
+ && ( runtimeDescriptorArray == rhs.runtimeDescriptorArray );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceDescriptorIndexingFeaturesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceDescriptorIndexingFeaturesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Bool32 shaderInputAttachmentArrayDynamicIndexing;\r
+ Bool32 shaderUniformTexelBufferArrayDynamicIndexing;\r
+ Bool32 shaderStorageTexelBufferArrayDynamicIndexing;\r
+ Bool32 shaderUniformBufferArrayNonUniformIndexing;\r
+ Bool32 shaderSampledImageArrayNonUniformIndexing;\r
+ Bool32 shaderStorageBufferArrayNonUniformIndexing;\r
+ Bool32 shaderStorageImageArrayNonUniformIndexing;\r
+ Bool32 shaderInputAttachmentArrayNonUniformIndexing;\r
+ Bool32 shaderUniformTexelBufferArrayNonUniformIndexing;\r
+ Bool32 shaderStorageTexelBufferArrayNonUniformIndexing;\r
+ Bool32 descriptorBindingUniformBufferUpdateAfterBind;\r
+ Bool32 descriptorBindingSampledImageUpdateAfterBind;\r
+ Bool32 descriptorBindingStorageImageUpdateAfterBind;\r
+ Bool32 descriptorBindingStorageBufferUpdateAfterBind;\r
+ Bool32 descriptorBindingUniformTexelBufferUpdateAfterBind;\r
+ Bool32 descriptorBindingStorageTexelBufferUpdateAfterBind;\r
+ Bool32 descriptorBindingUpdateUnusedWhilePending;\r
+ Bool32 descriptorBindingPartiallyBound;\r
+ Bool32 descriptorBindingVariableDescriptorCount;\r
+ Bool32 runtimeDescriptorArray;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceDescriptorIndexingFeaturesEXT ) == sizeof( VkPhysicalDeviceDescriptorIndexingFeaturesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceDescriptorIndexingPropertiesEXT\r
+ {\r
+ operator const VkPhysicalDeviceDescriptorIndexingPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceDescriptorIndexingPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceDescriptorIndexingPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxUpdateAfterBindDescriptorsInAllPools == rhs.maxUpdateAfterBindDescriptorsInAllPools )\r
+ && ( shaderUniformBufferArrayNonUniformIndexingNative == rhs.shaderUniformBufferArrayNonUniformIndexingNative )\r
+ && ( shaderSampledImageArrayNonUniformIndexingNative == rhs.shaderSampledImageArrayNonUniformIndexingNative )\r
+ && ( shaderStorageBufferArrayNonUniformIndexingNative == rhs.shaderStorageBufferArrayNonUniformIndexingNative )\r
+ && ( shaderStorageImageArrayNonUniformIndexingNative == rhs.shaderStorageImageArrayNonUniformIndexingNative )\r
+ && ( shaderInputAttachmentArrayNonUniformIndexingNative == rhs.shaderInputAttachmentArrayNonUniformIndexingNative )\r
+ && ( robustBufferAccessUpdateAfterBind == rhs.robustBufferAccessUpdateAfterBind )\r
+ && ( quadDivergentImplicitLod == rhs.quadDivergentImplicitLod )\r
+ && ( maxPerStageDescriptorUpdateAfterBindSamplers == rhs.maxPerStageDescriptorUpdateAfterBindSamplers )\r
+ && ( maxPerStageDescriptorUpdateAfterBindUniformBuffers == rhs.maxPerStageDescriptorUpdateAfterBindUniformBuffers )\r
+ && ( maxPerStageDescriptorUpdateAfterBindStorageBuffers == rhs.maxPerStageDescriptorUpdateAfterBindStorageBuffers )\r
+ && ( maxPerStageDescriptorUpdateAfterBindSampledImages == rhs.maxPerStageDescriptorUpdateAfterBindSampledImages )\r
+ && ( maxPerStageDescriptorUpdateAfterBindStorageImages == rhs.maxPerStageDescriptorUpdateAfterBindStorageImages )\r
+ && ( maxPerStageDescriptorUpdateAfterBindInputAttachments == rhs.maxPerStageDescriptorUpdateAfterBindInputAttachments )\r
+ && ( maxPerStageUpdateAfterBindResources == rhs.maxPerStageUpdateAfterBindResources )\r
+ && ( maxDescriptorSetUpdateAfterBindSamplers == rhs.maxDescriptorSetUpdateAfterBindSamplers )\r
+ && ( maxDescriptorSetUpdateAfterBindUniformBuffers == rhs.maxDescriptorSetUpdateAfterBindUniformBuffers )\r
+ && ( maxDescriptorSetUpdateAfterBindUniformBuffersDynamic == rhs.maxDescriptorSetUpdateAfterBindUniformBuffersDynamic )\r
+ && ( maxDescriptorSetUpdateAfterBindStorageBuffers == rhs.maxDescriptorSetUpdateAfterBindStorageBuffers )\r
+ && ( maxDescriptorSetUpdateAfterBindStorageBuffersDynamic == rhs.maxDescriptorSetUpdateAfterBindStorageBuffersDynamic )\r
+ && ( maxDescriptorSetUpdateAfterBindSampledImages == rhs.maxDescriptorSetUpdateAfterBindSampledImages )\r
+ && ( maxDescriptorSetUpdateAfterBindStorageImages == rhs.maxDescriptorSetUpdateAfterBindStorageImages )\r
+ && ( maxDescriptorSetUpdateAfterBindInputAttachments == rhs.maxDescriptorSetUpdateAfterBindInputAttachments );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceDescriptorIndexingPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceDescriptorIndexingPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxUpdateAfterBindDescriptorsInAllPools;\r
+ Bool32 shaderUniformBufferArrayNonUniformIndexingNative;\r
+ Bool32 shaderSampledImageArrayNonUniformIndexingNative;\r
+ Bool32 shaderStorageBufferArrayNonUniformIndexingNative;\r
+ Bool32 shaderStorageImageArrayNonUniformIndexingNative;\r
+ Bool32 shaderInputAttachmentArrayNonUniformIndexingNative;\r
+ Bool32 robustBufferAccessUpdateAfterBind;\r
+ Bool32 quadDivergentImplicitLod;\r
+ uint32_t maxPerStageDescriptorUpdateAfterBindSamplers;\r
+ uint32_t maxPerStageDescriptorUpdateAfterBindUniformBuffers;\r
+ uint32_t maxPerStageDescriptorUpdateAfterBindStorageBuffers;\r
+ uint32_t maxPerStageDescriptorUpdateAfterBindSampledImages;\r
+ uint32_t maxPerStageDescriptorUpdateAfterBindStorageImages;\r
+ uint32_t maxPerStageDescriptorUpdateAfterBindInputAttachments;\r
+ uint32_t maxPerStageUpdateAfterBindResources;\r
+ uint32_t maxDescriptorSetUpdateAfterBindSamplers;\r
+ uint32_t maxDescriptorSetUpdateAfterBindUniformBuffers;\r
+ uint32_t maxDescriptorSetUpdateAfterBindUniformBuffersDynamic;\r
+ uint32_t maxDescriptorSetUpdateAfterBindStorageBuffers;\r
+ uint32_t maxDescriptorSetUpdateAfterBindStorageBuffersDynamic;\r
+ uint32_t maxDescriptorSetUpdateAfterBindSampledImages;\r
+ uint32_t maxDescriptorSetUpdateAfterBindStorageImages;\r
+ uint32_t maxDescriptorSetUpdateAfterBindInputAttachments;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceDescriptorIndexingPropertiesEXT ) == sizeof( VkPhysicalDeviceDescriptorIndexingPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct DescriptorSetVariableDescriptorCountAllocateInfoEXT\r
+ {\r
+ DescriptorSetVariableDescriptorCountAllocateInfoEXT( uint32_t descriptorSetCount_ = 0, const uint32_t* pDescriptorCounts_ = nullptr )\r
+ : descriptorSetCount( descriptorSetCount_ )\r
+ , pDescriptorCounts( pDescriptorCounts_ )\r
+ {\r
+ }\r
+\r
+ DescriptorSetVariableDescriptorCountAllocateInfoEXT( VkDescriptorSetVariableDescriptorCountAllocateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetVariableDescriptorCountAllocateInfoEXT ) );\r
+ }\r
+\r
+ DescriptorSetVariableDescriptorCountAllocateInfoEXT& operator=( VkDescriptorSetVariableDescriptorCountAllocateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetVariableDescriptorCountAllocateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DescriptorSetVariableDescriptorCountAllocateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetVariableDescriptorCountAllocateInfoEXT& setDescriptorSetCount( uint32_t descriptorSetCount_ )\r
+ {\r
+ descriptorSetCount = descriptorSetCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetVariableDescriptorCountAllocateInfoEXT& setPDescriptorCounts( const uint32_t* pDescriptorCounts_ )\r
+ {\r
+ pDescriptorCounts = pDescriptorCounts_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorSetVariableDescriptorCountAllocateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetVariableDescriptorCountAllocateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetVariableDescriptorCountAllocateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( descriptorSetCount == rhs.descriptorSetCount )\r
+ && ( pDescriptorCounts == rhs.pDescriptorCounts );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetVariableDescriptorCountAllocateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorSetVariableDescriptorCountAllocateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t descriptorSetCount;\r
+ const uint32_t* pDescriptorCounts;\r
+ };\r
+ static_assert( sizeof( DescriptorSetVariableDescriptorCountAllocateInfoEXT ) == sizeof( VkDescriptorSetVariableDescriptorCountAllocateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct DescriptorSetVariableDescriptorCountLayoutSupportEXT\r
+ {\r
+ operator const VkDescriptorSetVariableDescriptorCountLayoutSupportEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetVariableDescriptorCountLayoutSupportEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetVariableDescriptorCountLayoutSupportEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxVariableDescriptorCount == rhs.maxVariableDescriptorCount );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetVariableDescriptorCountLayoutSupportEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorSetVariableDescriptorCountLayoutSupportEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxVariableDescriptorCount;\r
+ };\r
+ static_assert( sizeof( DescriptorSetVariableDescriptorCountLayoutSupportEXT ) == sizeof( VkDescriptorSetVariableDescriptorCountLayoutSupportEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineVertexInputDivisorStateCreateInfoEXT\r
+ {\r
+ PipelineVertexInputDivisorStateCreateInfoEXT( uint32_t vertexBindingDivisorCount_ = 0, const VertexInputBindingDivisorDescriptionEXT* pVertexBindingDivisors_ = nullptr )\r
+ : vertexBindingDivisorCount( vertexBindingDivisorCount_ )\r
+ , pVertexBindingDivisors( pVertexBindingDivisors_ )\r
+ {\r
+ }\r
+\r
+ PipelineVertexInputDivisorStateCreateInfoEXT( VkPipelineVertexInputDivisorStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineVertexInputDivisorStateCreateInfoEXT ) );\r
+ }\r
+\r
+ PipelineVertexInputDivisorStateCreateInfoEXT& operator=( VkPipelineVertexInputDivisorStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineVertexInputDivisorStateCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ PipelineVertexInputDivisorStateCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputDivisorStateCreateInfoEXT& setVertexBindingDivisorCount( uint32_t vertexBindingDivisorCount_ )\r
+ {\r
+ vertexBindingDivisorCount = vertexBindingDivisorCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineVertexInputDivisorStateCreateInfoEXT& setPVertexBindingDivisors( const VertexInputBindingDivisorDescriptionEXT* pVertexBindingDivisors_ )\r
+ {\r
+ pVertexBindingDivisors = pVertexBindingDivisors_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineVertexInputDivisorStateCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineVertexInputDivisorStateCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineVertexInputDivisorStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( vertexBindingDivisorCount == rhs.vertexBindingDivisorCount )\r
+ && ( pVertexBindingDivisors == rhs.pVertexBindingDivisors );\r
+ }\r
+\r
+ bool operator!=( PipelineVertexInputDivisorStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineVertexInputDivisorStateCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t vertexBindingDivisorCount;\r
+ const VertexInputBindingDivisorDescriptionEXT* pVertexBindingDivisors;\r
+ };\r
+ static_assert( sizeof( PipelineVertexInputDivisorStateCreateInfoEXT ) == sizeof( VkPipelineVertexInputDivisorStateCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceVertexAttributeDivisorPropertiesEXT\r
+ {\r
+ PhysicalDeviceVertexAttributeDivisorPropertiesEXT( uint32_t maxVertexAttribDivisor_ = 0 )\r
+ : maxVertexAttribDivisor( maxVertexAttribDivisor_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceVertexAttributeDivisorPropertiesEXT( VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceVertexAttributeDivisorPropertiesEXT ) );\r
+ }\r
+\r
+ PhysicalDeviceVertexAttributeDivisorPropertiesEXT& operator=( VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceVertexAttributeDivisorPropertiesEXT ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceVertexAttributeDivisorPropertiesEXT& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceVertexAttributeDivisorPropertiesEXT& setMaxVertexAttribDivisor( uint32_t maxVertexAttribDivisor_ )\r
+ {\r
+ maxVertexAttribDivisor = maxVertexAttribDivisor_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceVertexAttributeDivisorPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( maxVertexAttribDivisor == rhs.maxVertexAttribDivisor );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceVertexAttributeDivisorPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceVertexAttributeDivisorPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t maxVertexAttribDivisor;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceVertexAttributeDivisorPropertiesEXT ) == sizeof( VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ struct ImportAndroidHardwareBufferInfoANDROID\r
+ {\r
+ ImportAndroidHardwareBufferInfoANDROID( struct AHardwareBuffer* buffer_ = nullptr )\r
+ : buffer( buffer_ )\r
+ {\r
+ }\r
+\r
+ ImportAndroidHardwareBufferInfoANDROID( VkImportAndroidHardwareBufferInfoANDROID const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportAndroidHardwareBufferInfoANDROID ) );\r
+ }\r
+\r
+ ImportAndroidHardwareBufferInfoANDROID& operator=( VkImportAndroidHardwareBufferInfoANDROID const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportAndroidHardwareBufferInfoANDROID ) );\r
+ return *this;\r
+ }\r
+ ImportAndroidHardwareBufferInfoANDROID& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportAndroidHardwareBufferInfoANDROID& setBuffer( struct AHardwareBuffer* buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportAndroidHardwareBufferInfoANDROID&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportAndroidHardwareBufferInfoANDROID*>(this);\r
+ }\r
+\r
+ bool operator==( ImportAndroidHardwareBufferInfoANDROID const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( buffer == rhs.buffer );\r
+ }\r
+\r
+ bool operator!=( ImportAndroidHardwareBufferInfoANDROID const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportAndroidHardwareBufferInfoANDROID;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ struct AHardwareBuffer* buffer;\r
+ };\r
+ static_assert( sizeof( ImportAndroidHardwareBufferInfoANDROID ) == sizeof( VkImportAndroidHardwareBufferInfoANDROID ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ struct AndroidHardwareBufferUsageANDROID\r
+ {\r
+ operator const VkAndroidHardwareBufferUsageANDROID&() const\r
+ {\r
+ return *reinterpret_cast<const VkAndroidHardwareBufferUsageANDROID*>(this);\r
+ }\r
+\r
+ bool operator==( AndroidHardwareBufferUsageANDROID const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( androidHardwareBufferUsage == rhs.androidHardwareBufferUsage );\r
+ }\r
+\r
+ bool operator!=( AndroidHardwareBufferUsageANDROID const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eAndroidHardwareBufferUsageANDROID;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint64_t androidHardwareBufferUsage;\r
+ };\r
+ static_assert( sizeof( AndroidHardwareBufferUsageANDROID ) == sizeof( VkAndroidHardwareBufferUsageANDROID ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ struct AndroidHardwareBufferPropertiesANDROID\r
+ {\r
+ operator const VkAndroidHardwareBufferPropertiesANDROID&() const\r
+ {\r
+ return *reinterpret_cast<const VkAndroidHardwareBufferPropertiesANDROID*>(this);\r
+ }\r
+\r
+ bool operator==( AndroidHardwareBufferPropertiesANDROID const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( allocationSize == rhs.allocationSize )\r
+ && ( memoryTypeBits == rhs.memoryTypeBits );\r
+ }\r
+\r
+ bool operator!=( AndroidHardwareBufferPropertiesANDROID const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eAndroidHardwareBufferPropertiesANDROID;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ DeviceSize allocationSize;\r
+ uint32_t memoryTypeBits;\r
+ };\r
+ static_assert( sizeof( AndroidHardwareBufferPropertiesANDROID ) == sizeof( VkAndroidHardwareBufferPropertiesANDROID ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ struct MemoryGetAndroidHardwareBufferInfoANDROID\r
+ {\r
+ MemoryGetAndroidHardwareBufferInfoANDROID( DeviceMemory memory_ = DeviceMemory() )\r
+ : memory( memory_ )\r
+ {\r
+ }\r
+\r
+ MemoryGetAndroidHardwareBufferInfoANDROID( VkMemoryGetAndroidHardwareBufferInfoANDROID const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryGetAndroidHardwareBufferInfoANDROID ) );\r
+ }\r
+\r
+ MemoryGetAndroidHardwareBufferInfoANDROID& operator=( VkMemoryGetAndroidHardwareBufferInfoANDROID const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryGetAndroidHardwareBufferInfoANDROID ) );\r
+ return *this;\r
+ }\r
+ MemoryGetAndroidHardwareBufferInfoANDROID& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryGetAndroidHardwareBufferInfoANDROID& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryGetAndroidHardwareBufferInfoANDROID&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryGetAndroidHardwareBufferInfoANDROID*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryGetAndroidHardwareBufferInfoANDROID const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memory == rhs.memory );\r
+ }\r
+\r
+ bool operator!=( MemoryGetAndroidHardwareBufferInfoANDROID const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryGetAndroidHardwareBufferInfoANDROID;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceMemory memory;\r
+ };\r
+ static_assert( sizeof( MemoryGetAndroidHardwareBufferInfoANDROID ) == sizeof( VkMemoryGetAndroidHardwareBufferInfoANDROID ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ struct ExternalFormatANDROID\r
+ {\r
+ ExternalFormatANDROID( uint64_t externalFormat_ = 0 )\r
+ : externalFormat( externalFormat_ )\r
+ {\r
+ }\r
+\r
+ ExternalFormatANDROID( VkExternalFormatANDROID const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalFormatANDROID ) );\r
+ }\r
+\r
+ ExternalFormatANDROID& operator=( VkExternalFormatANDROID const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalFormatANDROID ) );\r
+ return *this;\r
+ }\r
+ ExternalFormatANDROID& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExternalFormatANDROID& setExternalFormat( uint64_t externalFormat_ )\r
+ {\r
+ externalFormat = externalFormat_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExternalFormatANDROID&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalFormatANDROID*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalFormatANDROID const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( externalFormat == rhs.externalFormat );\r
+ }\r
+\r
+ bool operator!=( ExternalFormatANDROID const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalFormatANDROID;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint64_t externalFormat;\r
+ };\r
+ static_assert( sizeof( ExternalFormatANDROID ) == sizeof( VkExternalFormatANDROID ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+ enum class SubpassContents\r
+ {\r
+ eInline = VK_SUBPASS_CONTENTS_INLINE,\r
+ eSecondaryCommandBuffers = VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS\r
+ };\r
+\r
+ struct PresentInfoKHR\r
+ {\r
+ PresentInfoKHR( uint32_t waitSemaphoreCount_ = 0, const Semaphore* pWaitSemaphores_ = nullptr, uint32_t swapchainCount_ = 0, const SwapchainKHR* pSwapchains_ = nullptr, const uint32_t* pImageIndices_ = nullptr, Result* pResults_ = nullptr )\r
+ : waitSemaphoreCount( waitSemaphoreCount_ )\r
+ , pWaitSemaphores( pWaitSemaphores_ )\r
+ , swapchainCount( swapchainCount_ )\r
+ , pSwapchains( pSwapchains_ )\r
+ , pImageIndices( pImageIndices_ )\r
+ , pResults( pResults_ )\r
+ {\r
+ }\r
+\r
+ PresentInfoKHR( VkPresentInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentInfoKHR ) );\r
+ }\r
+\r
+ PresentInfoKHR& operator=( VkPresentInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PresentInfoKHR ) );\r
+ return *this;\r
+ }\r
+ PresentInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PresentInfoKHR& setWaitSemaphoreCount( uint32_t waitSemaphoreCount_ )\r
+ {\r
+ waitSemaphoreCount = waitSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ PresentInfoKHR& setPWaitSemaphores( const Semaphore* pWaitSemaphores_ )\r
+ {\r
+ pWaitSemaphores = pWaitSemaphores_;\r
+ return *this;\r
+ }\r
+\r
+ PresentInfoKHR& setSwapchainCount( uint32_t swapchainCount_ )\r
+ {\r
+ swapchainCount = swapchainCount_;\r
+ return *this;\r
+ }\r
+\r
+ PresentInfoKHR& setPSwapchains( const SwapchainKHR* pSwapchains_ )\r
+ {\r
+ pSwapchains = pSwapchains_;\r
+ return *this;\r
+ }\r
+\r
+ PresentInfoKHR& setPImageIndices( const uint32_t* pImageIndices_ )\r
+ {\r
+ pImageIndices = pImageIndices_;\r
+ return *this;\r
+ }\r
+\r
+ PresentInfoKHR& setPResults( Result* pResults_ )\r
+ {\r
+ pResults = pResults_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPresentInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkPresentInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( PresentInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( waitSemaphoreCount == rhs.waitSemaphoreCount )\r
+ && ( pWaitSemaphores == rhs.pWaitSemaphores )\r
+ && ( swapchainCount == rhs.swapchainCount )\r
+ && ( pSwapchains == rhs.pSwapchains )\r
+ && ( pImageIndices == rhs.pImageIndices )\r
+ && ( pResults == rhs.pResults );\r
+ }\r
+\r
+ bool operator!=( PresentInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePresentInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t waitSemaphoreCount;\r
+ const Semaphore* pWaitSemaphores;\r
+ uint32_t swapchainCount;\r
+ const SwapchainKHR* pSwapchains;\r
+ const uint32_t* pImageIndices;\r
+ Result* pResults;\r
+ };\r
+ static_assert( sizeof( PresentInfoKHR ) == sizeof( VkPresentInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class DynamicState\r
+ {\r
+ eViewport = VK_DYNAMIC_STATE_VIEWPORT,\r
+ eScissor = VK_DYNAMIC_STATE_SCISSOR,\r
+ eLineWidth = VK_DYNAMIC_STATE_LINE_WIDTH,\r
+ eDepthBias = VK_DYNAMIC_STATE_DEPTH_BIAS,\r
+ eBlendConstants = VK_DYNAMIC_STATE_BLEND_CONSTANTS,\r
+ eDepthBounds = VK_DYNAMIC_STATE_DEPTH_BOUNDS,\r
+ eStencilCompareMask = VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK,\r
+ eStencilWriteMask = VK_DYNAMIC_STATE_STENCIL_WRITE_MASK,\r
+ eStencilReference = VK_DYNAMIC_STATE_STENCIL_REFERENCE,\r
+ eViewportWScalingNV = VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV,\r
+ eDiscardRectangleEXT = VK_DYNAMIC_STATE_DISCARD_RECTANGLE_EXT,\r
+ eSampleLocationsEXT = VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT\r
+ };\r
+\r
+ struct PipelineDynamicStateCreateInfo\r
+ {\r
+ PipelineDynamicStateCreateInfo( PipelineDynamicStateCreateFlags flags_ = PipelineDynamicStateCreateFlags(), uint32_t dynamicStateCount_ = 0, const DynamicState* pDynamicStates_ = nullptr )\r
+ : flags( flags_ )\r
+ , dynamicStateCount( dynamicStateCount_ )\r
+ , pDynamicStates( pDynamicStates_ )\r
+ {\r
+ }\r
+\r
+ PipelineDynamicStateCreateInfo( VkPipelineDynamicStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineDynamicStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineDynamicStateCreateInfo& operator=( VkPipelineDynamicStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineDynamicStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineDynamicStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDynamicStateCreateInfo& setFlags( PipelineDynamicStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDynamicStateCreateInfo& setDynamicStateCount( uint32_t dynamicStateCount_ )\r
+ {\r
+ dynamicStateCount = dynamicStateCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDynamicStateCreateInfo& setPDynamicStates( const DynamicState* pDynamicStates_ )\r
+ {\r
+ pDynamicStates = pDynamicStates_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineDynamicStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineDynamicStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineDynamicStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( dynamicStateCount == rhs.dynamicStateCount )\r
+ && ( pDynamicStates == rhs.pDynamicStates );\r
+ }\r
+\r
+ bool operator!=( PipelineDynamicStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineDynamicStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineDynamicStateCreateFlags flags;\r
+ uint32_t dynamicStateCount;\r
+ const DynamicState* pDynamicStates;\r
+ };\r
+ static_assert( sizeof( PipelineDynamicStateCreateInfo ) == sizeof( VkPipelineDynamicStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class DescriptorUpdateTemplateType\r
+ {\r
+ eDescriptorSet = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET,\r
+ eDescriptorSetKHR = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET,\r
+ ePushDescriptorsKHR = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR\r
+ };\r
+\r
+ struct DescriptorUpdateTemplateCreateInfo\r
+ {\r
+ DescriptorUpdateTemplateCreateInfo( DescriptorUpdateTemplateCreateFlags flags_ = DescriptorUpdateTemplateCreateFlags(), uint32_t descriptorUpdateEntryCount_ = 0, const DescriptorUpdateTemplateEntry* pDescriptorUpdateEntries_ = nullptr, DescriptorUpdateTemplateType templateType_ = DescriptorUpdateTemplateType::eDescriptorSet, DescriptorSetLayout descriptorSetLayout_ = DescriptorSetLayout(), PipelineBindPoint pipelineBindPoint_ = PipelineBindPoint::eGraphics, PipelineLayout pipelineLayout_ = PipelineLayout(), uint32_t set_ = 0 )\r
+ : flags( flags_ )\r
+ , descriptorUpdateEntryCount( descriptorUpdateEntryCount_ )\r
+ , pDescriptorUpdateEntries( pDescriptorUpdateEntries_ )\r
+ , templateType( templateType_ )\r
+ , descriptorSetLayout( descriptorSetLayout_ )\r
+ , pipelineBindPoint( pipelineBindPoint_ )\r
+ , pipelineLayout( pipelineLayout_ )\r
+ , set( set_ )\r
+ {\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo( VkDescriptorUpdateTemplateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorUpdateTemplateCreateInfo ) );\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& operator=( VkDescriptorUpdateTemplateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorUpdateTemplateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ DescriptorUpdateTemplateCreateInfo& setPNext( void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setFlags( DescriptorUpdateTemplateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setDescriptorUpdateEntryCount( uint32_t descriptorUpdateEntryCount_ )\r
+ {\r
+ descriptorUpdateEntryCount = descriptorUpdateEntryCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setPDescriptorUpdateEntries( const DescriptorUpdateTemplateEntry* pDescriptorUpdateEntries_ )\r
+ {\r
+ pDescriptorUpdateEntries = pDescriptorUpdateEntries_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setTemplateType( DescriptorUpdateTemplateType templateType_ )\r
+ {\r
+ templateType = templateType_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setDescriptorSetLayout( DescriptorSetLayout descriptorSetLayout_ )\r
+ {\r
+ descriptorSetLayout = descriptorSetLayout_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setPipelineBindPoint( PipelineBindPoint pipelineBindPoint_ )\r
+ {\r
+ pipelineBindPoint = pipelineBindPoint_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setPipelineLayout( PipelineLayout pipelineLayout_ )\r
+ {\r
+ pipelineLayout = pipelineLayout_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorUpdateTemplateCreateInfo& setSet( uint32_t set_ )\r
+ {\r
+ set = set_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorUpdateTemplateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorUpdateTemplateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( descriptorUpdateEntryCount == rhs.descriptorUpdateEntryCount )\r
+ && ( pDescriptorUpdateEntries == rhs.pDescriptorUpdateEntries )\r
+ && ( templateType == rhs.templateType )\r
+ && ( descriptorSetLayout == rhs.descriptorSetLayout )\r
+ && ( pipelineBindPoint == rhs.pipelineBindPoint )\r
+ && ( pipelineLayout == rhs.pipelineLayout )\r
+ && ( set == rhs.set );\r
+ }\r
+\r
+ bool operator!=( DescriptorUpdateTemplateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorUpdateTemplateCreateInfo;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ DescriptorUpdateTemplateCreateFlags flags;\r
+ uint32_t descriptorUpdateEntryCount;\r
+ const DescriptorUpdateTemplateEntry* pDescriptorUpdateEntries;\r
+ DescriptorUpdateTemplateType templateType;\r
+ DescriptorSetLayout descriptorSetLayout;\r
+ PipelineBindPoint pipelineBindPoint;\r
+ PipelineLayout pipelineLayout;\r
+ uint32_t set;\r
+ };\r
+ static_assert( sizeof( DescriptorUpdateTemplateCreateInfo ) == sizeof( VkDescriptorUpdateTemplateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using DescriptorUpdateTemplateCreateInfoKHR = DescriptorUpdateTemplateCreateInfo;\r
+\r
+ enum class ObjectType\r
+ {\r
+ eUnknown = VK_OBJECT_TYPE_UNKNOWN,\r
+ eInstance = VK_OBJECT_TYPE_INSTANCE,\r
+ ePhysicalDevice = VK_OBJECT_TYPE_PHYSICAL_DEVICE,\r
+ eDevice = VK_OBJECT_TYPE_DEVICE,\r
+ eQueue = VK_OBJECT_TYPE_QUEUE,\r
+ eSemaphore = VK_OBJECT_TYPE_SEMAPHORE,\r
+ eCommandBuffer = VK_OBJECT_TYPE_COMMAND_BUFFER,\r
+ eFence = VK_OBJECT_TYPE_FENCE,\r
+ eDeviceMemory = VK_OBJECT_TYPE_DEVICE_MEMORY,\r
+ eBuffer = VK_OBJECT_TYPE_BUFFER,\r
+ eImage = VK_OBJECT_TYPE_IMAGE,\r
+ eEvent = VK_OBJECT_TYPE_EVENT,\r
+ eQueryPool = VK_OBJECT_TYPE_QUERY_POOL,\r
+ eBufferView = VK_OBJECT_TYPE_BUFFER_VIEW,\r
+ eImageView = VK_OBJECT_TYPE_IMAGE_VIEW,\r
+ eShaderModule = VK_OBJECT_TYPE_SHADER_MODULE,\r
+ ePipelineCache = VK_OBJECT_TYPE_PIPELINE_CACHE,\r
+ ePipelineLayout = VK_OBJECT_TYPE_PIPELINE_LAYOUT,\r
+ eRenderPass = VK_OBJECT_TYPE_RENDER_PASS,\r
+ ePipeline = VK_OBJECT_TYPE_PIPELINE,\r
+ eDescriptorSetLayout = VK_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT,\r
+ eSampler = VK_OBJECT_TYPE_SAMPLER,\r
+ eDescriptorPool = VK_OBJECT_TYPE_DESCRIPTOR_POOL,\r
+ eDescriptorSet = VK_OBJECT_TYPE_DESCRIPTOR_SET,\r
+ eFramebuffer = VK_OBJECT_TYPE_FRAMEBUFFER,\r
+ eCommandPool = VK_OBJECT_TYPE_COMMAND_POOL,\r
+ eSamplerYcbcrConversion = VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION,\r
+ eSamplerYcbcrConversionKHR = VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION,\r
+ eDescriptorUpdateTemplate = VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE,\r
+ eDescriptorUpdateTemplateKHR = VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE,\r
+ eSurfaceKHR = VK_OBJECT_TYPE_SURFACE_KHR,\r
+ eSwapchainKHR = VK_OBJECT_TYPE_SWAPCHAIN_KHR,\r
+ eDisplayKHR = VK_OBJECT_TYPE_DISPLAY_KHR,\r
+ eDisplayModeKHR = VK_OBJECT_TYPE_DISPLAY_MODE_KHR,\r
+ eDebugReportCallbackEXT = VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT,\r
+ eObjectTableNVX = VK_OBJECT_TYPE_OBJECT_TABLE_NVX,\r
+ eIndirectCommandsLayoutNVX = VK_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX,\r
+ eDebugUtilsMessengerEXT = VK_OBJECT_TYPE_DEBUG_UTILS_MESSENGER_EXT,\r
+ eValidationCacheEXT = VK_OBJECT_TYPE_VALIDATION_CACHE_EXT\r
+ };\r
+\r
+ struct DebugUtilsObjectNameInfoEXT\r
+ {\r
+ DebugUtilsObjectNameInfoEXT( ObjectType objectType_ = ObjectType::eUnknown, uint64_t objectHandle_ = 0, const char* pObjectName_ = nullptr )\r
+ : objectType( objectType_ )\r
+ , objectHandle( objectHandle_ )\r
+ , pObjectName( pObjectName_ )\r
+ {\r
+ }\r
+\r
+ DebugUtilsObjectNameInfoEXT( VkDebugUtilsObjectNameInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsObjectNameInfoEXT ) );\r
+ }\r
+\r
+ DebugUtilsObjectNameInfoEXT& operator=( VkDebugUtilsObjectNameInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsObjectNameInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugUtilsObjectNameInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectNameInfoEXT& setObjectType( ObjectType objectType_ )\r
+ {\r
+ objectType = objectType_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectNameInfoEXT& setObjectHandle( uint64_t objectHandle_ )\r
+ {\r
+ objectHandle = objectHandle_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectNameInfoEXT& setPObjectName( const char* pObjectName_ )\r
+ {\r
+ pObjectName = pObjectName_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugUtilsObjectNameInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugUtilsObjectNameInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugUtilsObjectNameInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectType == rhs.objectType )\r
+ && ( objectHandle == rhs.objectHandle )\r
+ && ( pObjectName == rhs.pObjectName );\r
+ }\r
+\r
+ bool operator!=( DebugUtilsObjectNameInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugUtilsObjectNameInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ObjectType objectType;\r
+ uint64_t objectHandle;\r
+ const char* pObjectName;\r
+ };\r
+ static_assert( sizeof( DebugUtilsObjectNameInfoEXT ) == sizeof( VkDebugUtilsObjectNameInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct DebugUtilsObjectTagInfoEXT\r
+ {\r
+ DebugUtilsObjectTagInfoEXT( ObjectType objectType_ = ObjectType::eUnknown, uint64_t objectHandle_ = 0, uint64_t tagName_ = 0, size_t tagSize_ = 0, const void* pTag_ = nullptr )\r
+ : objectType( objectType_ )\r
+ , objectHandle( objectHandle_ )\r
+ , tagName( tagName_ )\r
+ , tagSize( tagSize_ )\r
+ , pTag( pTag_ )\r
+ {\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT( VkDebugUtilsObjectTagInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsObjectTagInfoEXT ) );\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT& operator=( VkDebugUtilsObjectTagInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsObjectTagInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugUtilsObjectTagInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT& setObjectType( ObjectType objectType_ )\r
+ {\r
+ objectType = objectType_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT& setObjectHandle( uint64_t objectHandle_ )\r
+ {\r
+ objectHandle = objectHandle_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT& setTagName( uint64_t tagName_ )\r
+ {\r
+ tagName = tagName_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT& setTagSize( size_t tagSize_ )\r
+ {\r
+ tagSize = tagSize_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsObjectTagInfoEXT& setPTag( const void* pTag_ )\r
+ {\r
+ pTag = pTag_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugUtilsObjectTagInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugUtilsObjectTagInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugUtilsObjectTagInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectType == rhs.objectType )\r
+ && ( objectHandle == rhs.objectHandle )\r
+ && ( tagName == rhs.tagName )\r
+ && ( tagSize == rhs.tagSize )\r
+ && ( pTag == rhs.pTag );\r
+ }\r
+\r
+ bool operator!=( DebugUtilsObjectTagInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugUtilsObjectTagInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ObjectType objectType;\r
+ uint64_t objectHandle;\r
+ uint64_t tagName;\r
+ size_t tagSize;\r
+ const void* pTag;\r
+ };\r
+ static_assert( sizeof( DebugUtilsObjectTagInfoEXT ) == sizeof( VkDebugUtilsObjectTagInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct DebugUtilsMessengerCallbackDataEXT\r
+ {\r
+ DebugUtilsMessengerCallbackDataEXT( DebugUtilsMessengerCallbackDataFlagsEXT flags_ = DebugUtilsMessengerCallbackDataFlagsEXT(), const char* pMessageIdName_ = nullptr, int32_t messageIdNumber_ = 0, const char* pMessage_ = nullptr, uint32_t queueLabelCount_ = 0, DebugUtilsLabelEXT* pQueueLabels_ = nullptr, uint32_t cmdBufLabelCount_ = 0, DebugUtilsLabelEXT* pCmdBufLabels_ = nullptr, uint32_t objectCount_ = 0, DebugUtilsObjectNameInfoEXT* pObjects_ = nullptr )\r
+ : flags( flags_ )\r
+ , pMessageIdName( pMessageIdName_ )\r
+ , messageIdNumber( messageIdNumber_ )\r
+ , pMessage( pMessage_ )\r
+ , queueLabelCount( queueLabelCount_ )\r
+ , pQueueLabels( pQueueLabels_ )\r
+ , cmdBufLabelCount( cmdBufLabelCount_ )\r
+ , pCmdBufLabels( pCmdBufLabels_ )\r
+ , objectCount( objectCount_ )\r
+ , pObjects( pObjects_ )\r
+ {\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT( VkDebugUtilsMessengerCallbackDataEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsMessengerCallbackDataEXT ) );\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& operator=( VkDebugUtilsMessengerCallbackDataEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsMessengerCallbackDataEXT ) );\r
+ return *this;\r
+ }\r
+ DebugUtilsMessengerCallbackDataEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setFlags( DebugUtilsMessengerCallbackDataFlagsEXT flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setPMessageIdName( const char* pMessageIdName_ )\r
+ {\r
+ pMessageIdName = pMessageIdName_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setMessageIdNumber( int32_t messageIdNumber_ )\r
+ {\r
+ messageIdNumber = messageIdNumber_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setPMessage( const char* pMessage_ )\r
+ {\r
+ pMessage = pMessage_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setQueueLabelCount( uint32_t queueLabelCount_ )\r
+ {\r
+ queueLabelCount = queueLabelCount_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setPQueueLabels( DebugUtilsLabelEXT* pQueueLabels_ )\r
+ {\r
+ pQueueLabels = pQueueLabels_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setCmdBufLabelCount( uint32_t cmdBufLabelCount_ )\r
+ {\r
+ cmdBufLabelCount = cmdBufLabelCount_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setPCmdBufLabels( DebugUtilsLabelEXT* pCmdBufLabels_ )\r
+ {\r
+ pCmdBufLabels = pCmdBufLabels_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setObjectCount( uint32_t objectCount_ )\r
+ {\r
+ objectCount = objectCount_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCallbackDataEXT& setPObjects( DebugUtilsObjectNameInfoEXT* pObjects_ )\r
+ {\r
+ pObjects = pObjects_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugUtilsMessengerCallbackDataEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugUtilsMessengerCallbackDataEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugUtilsMessengerCallbackDataEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( pMessageIdName == rhs.pMessageIdName )\r
+ && ( messageIdNumber == rhs.messageIdNumber )\r
+ && ( pMessage == rhs.pMessage )\r
+ && ( queueLabelCount == rhs.queueLabelCount )\r
+ && ( pQueueLabels == rhs.pQueueLabels )\r
+ && ( cmdBufLabelCount == rhs.cmdBufLabelCount )\r
+ && ( pCmdBufLabels == rhs.pCmdBufLabels )\r
+ && ( objectCount == rhs.objectCount )\r
+ && ( pObjects == rhs.pObjects );\r
+ }\r
+\r
+ bool operator!=( DebugUtilsMessengerCallbackDataEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugUtilsMessengerCallbackDataEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DebugUtilsMessengerCallbackDataFlagsEXT flags;\r
+ const char* pMessageIdName;\r
+ int32_t messageIdNumber;\r
+ const char* pMessage;\r
+ uint32_t queueLabelCount;\r
+ DebugUtilsLabelEXT* pQueueLabels;\r
+ uint32_t cmdBufLabelCount;\r
+ DebugUtilsLabelEXT* pCmdBufLabels;\r
+ uint32_t objectCount;\r
+ DebugUtilsObjectNameInfoEXT* pObjects;\r
+ };\r
+ static_assert( sizeof( DebugUtilsMessengerCallbackDataEXT ) == sizeof( VkDebugUtilsMessengerCallbackDataEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class QueueFlagBits\r
+ {\r
+ eGraphics = VK_QUEUE_GRAPHICS_BIT,\r
+ eCompute = VK_QUEUE_COMPUTE_BIT,\r
+ eTransfer = VK_QUEUE_TRANSFER_BIT,\r
+ eSparseBinding = VK_QUEUE_SPARSE_BINDING_BIT,\r
+ eProtected = VK_QUEUE_PROTECTED_BIT\r
+ };\r
+\r
+ using QueueFlags = Flags<QueueFlagBits, VkQueueFlags>;\r
+\r
+ VULKAN_HPP_INLINE QueueFlags operator|( QueueFlagBits bit0, QueueFlagBits bit1 )\r
+ {\r
+ return QueueFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE QueueFlags operator~( QueueFlagBits bits )\r
+ {\r
+ return ~( QueueFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<QueueFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(QueueFlagBits::eGraphics) | VkFlags(QueueFlagBits::eCompute) | VkFlags(QueueFlagBits::eTransfer) | VkFlags(QueueFlagBits::eSparseBinding) | VkFlags(QueueFlagBits::eProtected)\r
+ };\r
+ };\r
+\r
+ struct QueueFamilyProperties\r
+ {\r
+ operator const VkQueueFamilyProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkQueueFamilyProperties*>(this);\r
+ }\r
+\r
+ bool operator==( QueueFamilyProperties const& rhs ) const\r
+ {\r
+ return ( queueFlags == rhs.queueFlags )\r
+ && ( queueCount == rhs.queueCount )\r
+ && ( timestampValidBits == rhs.timestampValidBits )\r
+ && ( minImageTransferGranularity == rhs.minImageTransferGranularity );\r
+ }\r
+\r
+ bool operator!=( QueueFamilyProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ QueueFlags queueFlags;\r
+ uint32_t queueCount;\r
+ uint32_t timestampValidBits;\r
+ Extent3D minImageTransferGranularity;\r
+ };\r
+ static_assert( sizeof( QueueFamilyProperties ) == sizeof( VkQueueFamilyProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct QueueFamilyProperties2\r
+ {\r
+ operator const VkQueueFamilyProperties2&() const\r
+ {\r
+ return *reinterpret_cast<const VkQueueFamilyProperties2*>(this);\r
+ }\r
+\r
+ bool operator==( QueueFamilyProperties2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( queueFamilyProperties == rhs.queueFamilyProperties );\r
+ }\r
+\r
+ bool operator!=( QueueFamilyProperties2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eQueueFamilyProperties2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ QueueFamilyProperties queueFamilyProperties;\r
+ };\r
+ static_assert( sizeof( QueueFamilyProperties2 ) == sizeof( VkQueueFamilyProperties2 ), "struct and wrapper have different size!" );\r
+\r
+ using QueueFamilyProperties2KHR = QueueFamilyProperties2;\r
+\r
+ enum class DeviceQueueCreateFlagBits\r
+ {\r
+ eProtected = VK_DEVICE_QUEUE_CREATE_PROTECTED_BIT\r
+ };\r
+\r
+ using DeviceQueueCreateFlags = Flags<DeviceQueueCreateFlagBits, VkDeviceQueueCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE DeviceQueueCreateFlags operator|( DeviceQueueCreateFlagBits bit0, DeviceQueueCreateFlagBits bit1 )\r
+ {\r
+ return DeviceQueueCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DeviceQueueCreateFlags operator~( DeviceQueueCreateFlagBits bits )\r
+ {\r
+ return ~( DeviceQueueCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DeviceQueueCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DeviceQueueCreateFlagBits::eProtected)\r
+ };\r
+ };\r
+\r
+ struct DeviceQueueCreateInfo\r
+ {\r
+ DeviceQueueCreateInfo( DeviceQueueCreateFlags flags_ = DeviceQueueCreateFlags(), uint32_t queueFamilyIndex_ = 0, uint32_t queueCount_ = 0, const float* pQueuePriorities_ = nullptr )\r
+ : flags( flags_ )\r
+ , queueFamilyIndex( queueFamilyIndex_ )\r
+ , queueCount( queueCount_ )\r
+ , pQueuePriorities( pQueuePriorities_ )\r
+ {\r
+ }\r
+\r
+ DeviceQueueCreateInfo( VkDeviceQueueCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceQueueCreateInfo ) );\r
+ }\r
+\r
+ DeviceQueueCreateInfo& operator=( VkDeviceQueueCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceQueueCreateInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceQueueCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueCreateInfo& setFlags( DeviceQueueCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueCreateInfo& setQueueFamilyIndex( uint32_t queueFamilyIndex_ )\r
+ {\r
+ queueFamilyIndex = queueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueCreateInfo& setQueueCount( uint32_t queueCount_ )\r
+ {\r
+ queueCount = queueCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueCreateInfo& setPQueuePriorities( const float* pQueuePriorities_ )\r
+ {\r
+ pQueuePriorities = pQueuePriorities_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceQueueCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceQueueCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceQueueCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( queueFamilyIndex == rhs.queueFamilyIndex )\r
+ && ( queueCount == rhs.queueCount )\r
+ && ( pQueuePriorities == rhs.pQueuePriorities );\r
+ }\r
+\r
+ bool operator!=( DeviceQueueCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceQueueCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceQueueCreateFlags flags;\r
+ uint32_t queueFamilyIndex;\r
+ uint32_t queueCount;\r
+ const float* pQueuePriorities;\r
+ };\r
+ static_assert( sizeof( DeviceQueueCreateInfo ) == sizeof( VkDeviceQueueCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct DeviceCreateInfo\r
+ {\r
+ DeviceCreateInfo( DeviceCreateFlags flags_ = DeviceCreateFlags(), uint32_t queueCreateInfoCount_ = 0, const DeviceQueueCreateInfo* pQueueCreateInfos_ = nullptr, uint32_t enabledLayerCount_ = 0, const char* const* ppEnabledLayerNames_ = nullptr, uint32_t enabledExtensionCount_ = 0, const char* const* ppEnabledExtensionNames_ = nullptr, const PhysicalDeviceFeatures* pEnabledFeatures_ = nullptr )\r
+ : flags( flags_ )\r
+ , queueCreateInfoCount( queueCreateInfoCount_ )\r
+ , pQueueCreateInfos( pQueueCreateInfos_ )\r
+ , enabledLayerCount( enabledLayerCount_ )\r
+ , ppEnabledLayerNames( ppEnabledLayerNames_ )\r
+ , enabledExtensionCount( enabledExtensionCount_ )\r
+ , ppEnabledExtensionNames( ppEnabledExtensionNames_ )\r
+ , pEnabledFeatures( pEnabledFeatures_ )\r
+ {\r
+ }\r
+\r
+ DeviceCreateInfo( VkDeviceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceCreateInfo ) );\r
+ }\r
+\r
+ DeviceCreateInfo& operator=( VkDeviceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceCreateInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setFlags( DeviceCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setQueueCreateInfoCount( uint32_t queueCreateInfoCount_ )\r
+ {\r
+ queueCreateInfoCount = queueCreateInfoCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setPQueueCreateInfos( const DeviceQueueCreateInfo* pQueueCreateInfos_ )\r
+ {\r
+ pQueueCreateInfos = pQueueCreateInfos_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setEnabledLayerCount( uint32_t enabledLayerCount_ )\r
+ {\r
+ enabledLayerCount = enabledLayerCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setPpEnabledLayerNames( const char* const* ppEnabledLayerNames_ )\r
+ {\r
+ ppEnabledLayerNames = ppEnabledLayerNames_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setEnabledExtensionCount( uint32_t enabledExtensionCount_ )\r
+ {\r
+ enabledExtensionCount = enabledExtensionCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setPpEnabledExtensionNames( const char* const* ppEnabledExtensionNames_ )\r
+ {\r
+ ppEnabledExtensionNames = ppEnabledExtensionNames_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceCreateInfo& setPEnabledFeatures( const PhysicalDeviceFeatures* pEnabledFeatures_ )\r
+ {\r
+ pEnabledFeatures = pEnabledFeatures_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( queueCreateInfoCount == rhs.queueCreateInfoCount )\r
+ && ( pQueueCreateInfos == rhs.pQueueCreateInfos )\r
+ && ( enabledLayerCount == rhs.enabledLayerCount )\r
+ && ( ppEnabledLayerNames == rhs.ppEnabledLayerNames )\r
+ && ( enabledExtensionCount == rhs.enabledExtensionCount )\r
+ && ( ppEnabledExtensionNames == rhs.ppEnabledExtensionNames )\r
+ && ( pEnabledFeatures == rhs.pEnabledFeatures );\r
+ }\r
+\r
+ bool operator!=( DeviceCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceCreateFlags flags;\r
+ uint32_t queueCreateInfoCount;\r
+ const DeviceQueueCreateInfo* pQueueCreateInfos;\r
+ uint32_t enabledLayerCount;\r
+ const char* const* ppEnabledLayerNames;\r
+ uint32_t enabledExtensionCount;\r
+ const char* const* ppEnabledExtensionNames;\r
+ const PhysicalDeviceFeatures* pEnabledFeatures;\r
+ };\r
+ static_assert( sizeof( DeviceCreateInfo ) == sizeof( VkDeviceCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct DeviceQueueInfo2\r
+ {\r
+ DeviceQueueInfo2( DeviceQueueCreateFlags flags_ = DeviceQueueCreateFlags(), uint32_t queueFamilyIndex_ = 0, uint32_t queueIndex_ = 0 )\r
+ : flags( flags_ )\r
+ , queueFamilyIndex( queueFamilyIndex_ )\r
+ , queueIndex( queueIndex_ )\r
+ {\r
+ }\r
+\r
+ DeviceQueueInfo2( VkDeviceQueueInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceQueueInfo2 ) );\r
+ }\r
+\r
+ DeviceQueueInfo2& operator=( VkDeviceQueueInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceQueueInfo2 ) );\r
+ return *this;\r
+ }\r
+ DeviceQueueInfo2& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueInfo2& setFlags( DeviceQueueCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueInfo2& setQueueFamilyIndex( uint32_t queueFamilyIndex_ )\r
+ {\r
+ queueFamilyIndex = queueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueInfo2& setQueueIndex( uint32_t queueIndex_ )\r
+ {\r
+ queueIndex = queueIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceQueueInfo2&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceQueueInfo2*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceQueueInfo2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( queueFamilyIndex == rhs.queueFamilyIndex )\r
+ && ( queueIndex == rhs.queueIndex );\r
+ }\r
+\r
+ bool operator!=( DeviceQueueInfo2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceQueueInfo2;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceQueueCreateFlags flags;\r
+ uint32_t queueFamilyIndex;\r
+ uint32_t queueIndex;\r
+ };\r
+ static_assert( sizeof( DeviceQueueInfo2 ) == sizeof( VkDeviceQueueInfo2 ), "struct and wrapper have different size!" );\r
+\r
+ enum class MemoryPropertyFlagBits\r
+ {\r
+ eDeviceLocal = VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT,\r
+ eHostVisible = VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT,\r
+ eHostCoherent = VK_MEMORY_PROPERTY_HOST_COHERENT_BIT,\r
+ eHostCached = VK_MEMORY_PROPERTY_HOST_CACHED_BIT,\r
+ eLazilyAllocated = VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT,\r
+ eProtected = VK_MEMORY_PROPERTY_PROTECTED_BIT\r
+ };\r
+\r
+ using MemoryPropertyFlags = Flags<MemoryPropertyFlagBits, VkMemoryPropertyFlags>;\r
+\r
+ VULKAN_HPP_INLINE MemoryPropertyFlags operator|( MemoryPropertyFlagBits bit0, MemoryPropertyFlagBits bit1 )\r
+ {\r
+ return MemoryPropertyFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE MemoryPropertyFlags operator~( MemoryPropertyFlagBits bits )\r
+ {\r
+ return ~( MemoryPropertyFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<MemoryPropertyFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(MemoryPropertyFlagBits::eDeviceLocal) | VkFlags(MemoryPropertyFlagBits::eHostVisible) | VkFlags(MemoryPropertyFlagBits::eHostCoherent) | VkFlags(MemoryPropertyFlagBits::eHostCached) | VkFlags(MemoryPropertyFlagBits::eLazilyAllocated) | VkFlags(MemoryPropertyFlagBits::eProtected)\r
+ };\r
+ };\r
+\r
+ struct MemoryType\r
+ {\r
+ operator const VkMemoryType&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryType*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryType const& rhs ) const\r
+ {\r
+ return ( propertyFlags == rhs.propertyFlags )\r
+ && ( heapIndex == rhs.heapIndex );\r
+ }\r
+\r
+ bool operator!=( MemoryType const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ MemoryPropertyFlags propertyFlags;\r
+ uint32_t heapIndex;\r
+ };\r
+ static_assert( sizeof( MemoryType ) == sizeof( VkMemoryType ), "struct and wrapper have different size!" );\r
+\r
+ enum class MemoryHeapFlagBits\r
+ {\r
+ eDeviceLocal = VK_MEMORY_HEAP_DEVICE_LOCAL_BIT,\r
+ eMultiInstance = VK_MEMORY_HEAP_MULTI_INSTANCE_BIT,\r
+ eMultiInstanceKHR = VK_MEMORY_HEAP_MULTI_INSTANCE_BIT\r
+ };\r
+\r
+ using MemoryHeapFlags = Flags<MemoryHeapFlagBits, VkMemoryHeapFlags>;\r
+\r
+ VULKAN_HPP_INLINE MemoryHeapFlags operator|( MemoryHeapFlagBits bit0, MemoryHeapFlagBits bit1 )\r
+ {\r
+ return MemoryHeapFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE MemoryHeapFlags operator~( MemoryHeapFlagBits bits )\r
+ {\r
+ return ~( MemoryHeapFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<MemoryHeapFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(MemoryHeapFlagBits::eDeviceLocal) | VkFlags(MemoryHeapFlagBits::eMultiInstance)\r
+ };\r
+ };\r
+\r
+ struct MemoryHeap\r
+ {\r
+ operator const VkMemoryHeap&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryHeap*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryHeap const& rhs ) const\r
+ {\r
+ return ( size == rhs.size )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( MemoryHeap const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DeviceSize size;\r
+ MemoryHeapFlags flags;\r
+ };\r
+ static_assert( sizeof( MemoryHeap ) == sizeof( VkMemoryHeap ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceMemoryProperties\r
+ {\r
+ operator const VkPhysicalDeviceMemoryProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceMemoryProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceMemoryProperties const& rhs ) const\r
+ {\r
+ return ( memoryTypeCount == rhs.memoryTypeCount )\r
+ && ( memcmp( memoryTypes, rhs.memoryTypes, VK_MAX_MEMORY_TYPES * sizeof( MemoryType ) ) == 0 )\r
+ && ( memoryHeapCount == rhs.memoryHeapCount )\r
+ && ( memcmp( memoryHeaps, rhs.memoryHeaps, VK_MAX_MEMORY_HEAPS * sizeof( MemoryHeap ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceMemoryProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t memoryTypeCount;\r
+ MemoryType memoryTypes[VK_MAX_MEMORY_TYPES];\r
+ uint32_t memoryHeapCount;\r
+ MemoryHeap memoryHeaps[VK_MAX_MEMORY_HEAPS];\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceMemoryProperties ) == sizeof( VkPhysicalDeviceMemoryProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceMemoryProperties2\r
+ {\r
+ operator const VkPhysicalDeviceMemoryProperties2&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceMemoryProperties2*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceMemoryProperties2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memoryProperties == rhs.memoryProperties );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceMemoryProperties2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceMemoryProperties2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ PhysicalDeviceMemoryProperties memoryProperties;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceMemoryProperties2 ) == sizeof( VkPhysicalDeviceMemoryProperties2 ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceMemoryProperties2KHR = PhysicalDeviceMemoryProperties2;\r
+\r
+ enum class AccessFlagBits\r
+ {\r
+ eIndirectCommandRead = VK_ACCESS_INDIRECT_COMMAND_READ_BIT,\r
+ eIndexRead = VK_ACCESS_INDEX_READ_BIT,\r
+ eVertexAttributeRead = VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT,\r
+ eUniformRead = VK_ACCESS_UNIFORM_READ_BIT,\r
+ eInputAttachmentRead = VK_ACCESS_INPUT_ATTACHMENT_READ_BIT,\r
+ eShaderRead = VK_ACCESS_SHADER_READ_BIT,\r
+ eShaderWrite = VK_ACCESS_SHADER_WRITE_BIT,\r
+ eColorAttachmentRead = VK_ACCESS_COLOR_ATTACHMENT_READ_BIT,\r
+ eColorAttachmentWrite = VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT,\r
+ eDepthStencilAttachmentRead = VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT,\r
+ eDepthStencilAttachmentWrite = VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT,\r
+ eTransferRead = VK_ACCESS_TRANSFER_READ_BIT,\r
+ eTransferWrite = VK_ACCESS_TRANSFER_WRITE_BIT,\r
+ eHostRead = VK_ACCESS_HOST_READ_BIT,\r
+ eHostWrite = VK_ACCESS_HOST_WRITE_BIT,\r
+ eMemoryRead = VK_ACCESS_MEMORY_READ_BIT,\r
+ eMemoryWrite = VK_ACCESS_MEMORY_WRITE_BIT,\r
+ eCommandProcessReadNVX = VK_ACCESS_COMMAND_PROCESS_READ_BIT_NVX,\r
+ eCommandProcessWriteNVX = VK_ACCESS_COMMAND_PROCESS_WRITE_BIT_NVX,\r
+ eColorAttachmentReadNoncoherentEXT = VK_ACCESS_COLOR_ATTACHMENT_READ_NONCOHERENT_BIT_EXT\r
+ };\r
+\r
+ using AccessFlags = Flags<AccessFlagBits, VkAccessFlags>;\r
+\r
+ VULKAN_HPP_INLINE AccessFlags operator|( AccessFlagBits bit0, AccessFlagBits bit1 )\r
+ {\r
+ return AccessFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE AccessFlags operator~( AccessFlagBits bits )\r
+ {\r
+ return ~( AccessFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<AccessFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(AccessFlagBits::eIndirectCommandRead) | VkFlags(AccessFlagBits::eIndexRead) | VkFlags(AccessFlagBits::eVertexAttributeRead) | VkFlags(AccessFlagBits::eUniformRead) | VkFlags(AccessFlagBits::eInputAttachmentRead) | VkFlags(AccessFlagBits::eShaderRead) | VkFlags(AccessFlagBits::eShaderWrite) | VkFlags(AccessFlagBits::eColorAttachmentRead) | VkFlags(AccessFlagBits::eColorAttachmentWrite) | VkFlags(AccessFlagBits::eDepthStencilAttachmentRead) | VkFlags(AccessFlagBits::eDepthStencilAttachmentWrite) | VkFlags(AccessFlagBits::eTransferRead) | VkFlags(AccessFlagBits::eTransferWrite) | VkFlags(AccessFlagBits::eHostRead) | VkFlags(AccessFlagBits::eHostWrite) | VkFlags(AccessFlagBits::eMemoryRead) | VkFlags(AccessFlagBits::eMemoryWrite) | VkFlags(AccessFlagBits::eCommandProcessReadNVX) | VkFlags(AccessFlagBits::eCommandProcessWriteNVX) | VkFlags(AccessFlagBits::eColorAttachmentReadNoncoherentEXT)\r
+ };\r
+ };\r
+\r
+ struct MemoryBarrier\r
+ {\r
+ MemoryBarrier( AccessFlags srcAccessMask_ = AccessFlags(), AccessFlags dstAccessMask_ = AccessFlags() )\r
+ : srcAccessMask( srcAccessMask_ )\r
+ , dstAccessMask( dstAccessMask_ )\r
+ {\r
+ }\r
+\r
+ MemoryBarrier( VkMemoryBarrier const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryBarrier ) );\r
+ }\r
+\r
+ MemoryBarrier& operator=( VkMemoryBarrier const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryBarrier ) );\r
+ return *this;\r
+ }\r
+ MemoryBarrier& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryBarrier& setSrcAccessMask( AccessFlags srcAccessMask_ )\r
+ {\r
+ srcAccessMask = srcAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryBarrier& setDstAccessMask( AccessFlags dstAccessMask_ )\r
+ {\r
+ dstAccessMask = dstAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryBarrier&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryBarrier*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryBarrier const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( srcAccessMask == rhs.srcAccessMask )\r
+ && ( dstAccessMask == rhs.dstAccessMask );\r
+ }\r
+\r
+ bool operator!=( MemoryBarrier const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryBarrier;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ AccessFlags srcAccessMask;\r
+ AccessFlags dstAccessMask;\r
+ };\r
+ static_assert( sizeof( MemoryBarrier ) == sizeof( VkMemoryBarrier ), "struct and wrapper have different size!" );\r
+\r
+ struct BufferMemoryBarrier\r
+ {\r
+ BufferMemoryBarrier( AccessFlags srcAccessMask_ = AccessFlags(), AccessFlags dstAccessMask_ = AccessFlags(), uint32_t srcQueueFamilyIndex_ = 0, uint32_t dstQueueFamilyIndex_ = 0, Buffer buffer_ = Buffer(), DeviceSize offset_ = 0, DeviceSize size_ = 0 )\r
+ : srcAccessMask( srcAccessMask_ )\r
+ , dstAccessMask( dstAccessMask_ )\r
+ , srcQueueFamilyIndex( srcQueueFamilyIndex_ )\r
+ , dstQueueFamilyIndex( dstQueueFamilyIndex_ )\r
+ , buffer( buffer_ )\r
+ , offset( offset_ )\r
+ , size( size_ )\r
+ {\r
+ }\r
+\r
+ BufferMemoryBarrier( VkBufferMemoryBarrier const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferMemoryBarrier ) );\r
+ }\r
+\r
+ BufferMemoryBarrier& operator=( VkBufferMemoryBarrier const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferMemoryBarrier ) );\r
+ return *this;\r
+ }\r
+ BufferMemoryBarrier& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setSrcAccessMask( AccessFlags srcAccessMask_ )\r
+ {\r
+ srcAccessMask = srcAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setDstAccessMask( AccessFlags dstAccessMask_ )\r
+ {\r
+ dstAccessMask = dstAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setSrcQueueFamilyIndex( uint32_t srcQueueFamilyIndex_ )\r
+ {\r
+ srcQueueFamilyIndex = srcQueueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setDstQueueFamilyIndex( uint32_t dstQueueFamilyIndex_ )\r
+ {\r
+ dstQueueFamilyIndex = dstQueueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setOffset( DeviceSize offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ BufferMemoryBarrier& setSize( DeviceSize size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBufferMemoryBarrier&() const\r
+ {\r
+ return *reinterpret_cast<const VkBufferMemoryBarrier*>(this);\r
+ }\r
+\r
+ bool operator==( BufferMemoryBarrier const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( srcAccessMask == rhs.srcAccessMask )\r
+ && ( dstAccessMask == rhs.dstAccessMask )\r
+ && ( srcQueueFamilyIndex == rhs.srcQueueFamilyIndex )\r
+ && ( dstQueueFamilyIndex == rhs.dstQueueFamilyIndex )\r
+ && ( buffer == rhs.buffer )\r
+ && ( offset == rhs.offset )\r
+ && ( size == rhs.size );\r
+ }\r
+\r
+ bool operator!=( BufferMemoryBarrier const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBufferMemoryBarrier;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ AccessFlags srcAccessMask;\r
+ AccessFlags dstAccessMask;\r
+ uint32_t srcQueueFamilyIndex;\r
+ uint32_t dstQueueFamilyIndex;\r
+ Buffer buffer;\r
+ DeviceSize offset;\r
+ DeviceSize size;\r
+ };\r
+ static_assert( sizeof( BufferMemoryBarrier ) == sizeof( VkBufferMemoryBarrier ), "struct and wrapper have different size!" );\r
+\r
+ enum class BufferUsageFlagBits\r
+ {\r
+ eTransferSrc = VK_BUFFER_USAGE_TRANSFER_SRC_BIT,\r
+ eTransferDst = VK_BUFFER_USAGE_TRANSFER_DST_BIT,\r
+ eUniformTexelBuffer = VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT,\r
+ eStorageTexelBuffer = VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT,\r
+ eUniformBuffer = VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT,\r
+ eStorageBuffer = VK_BUFFER_USAGE_STORAGE_BUFFER_BIT,\r
+ eIndexBuffer = VK_BUFFER_USAGE_INDEX_BUFFER_BIT,\r
+ eVertexBuffer = VK_BUFFER_USAGE_VERTEX_BUFFER_BIT,\r
+ eIndirectBuffer = VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT\r
+ };\r
+\r
+ using BufferUsageFlags = Flags<BufferUsageFlagBits, VkBufferUsageFlags>;\r
+\r
+ VULKAN_HPP_INLINE BufferUsageFlags operator|( BufferUsageFlagBits bit0, BufferUsageFlagBits bit1 )\r
+ {\r
+ return BufferUsageFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE BufferUsageFlags operator~( BufferUsageFlagBits bits )\r
+ {\r
+ return ~( BufferUsageFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<BufferUsageFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(BufferUsageFlagBits::eTransferSrc) | VkFlags(BufferUsageFlagBits::eTransferDst) | VkFlags(BufferUsageFlagBits::eUniformTexelBuffer) | VkFlags(BufferUsageFlagBits::eStorageTexelBuffer) | VkFlags(BufferUsageFlagBits::eUniformBuffer) | VkFlags(BufferUsageFlagBits::eStorageBuffer) | VkFlags(BufferUsageFlagBits::eIndexBuffer) | VkFlags(BufferUsageFlagBits::eVertexBuffer) | VkFlags(BufferUsageFlagBits::eIndirectBuffer)\r
+ };\r
+ };\r
+\r
+ enum class BufferCreateFlagBits\r
+ {\r
+ eSparseBinding = VK_BUFFER_CREATE_SPARSE_BINDING_BIT,\r
+ eSparseResidency = VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT,\r
+ eSparseAliased = VK_BUFFER_CREATE_SPARSE_ALIASED_BIT,\r
+ eProtected = VK_BUFFER_CREATE_PROTECTED_BIT\r
+ };\r
+\r
+ using BufferCreateFlags = Flags<BufferCreateFlagBits, VkBufferCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE BufferCreateFlags operator|( BufferCreateFlagBits bit0, BufferCreateFlagBits bit1 )\r
+ {\r
+ return BufferCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE BufferCreateFlags operator~( BufferCreateFlagBits bits )\r
+ {\r
+ return ~( BufferCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<BufferCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(BufferCreateFlagBits::eSparseBinding) | VkFlags(BufferCreateFlagBits::eSparseResidency) | VkFlags(BufferCreateFlagBits::eSparseAliased) | VkFlags(BufferCreateFlagBits::eProtected)\r
+ };\r
+ };\r
+\r
+ struct BufferCreateInfo\r
+ {\r
+ BufferCreateInfo( BufferCreateFlags flags_ = BufferCreateFlags(), DeviceSize size_ = 0, BufferUsageFlags usage_ = BufferUsageFlags(), SharingMode sharingMode_ = SharingMode::eExclusive, uint32_t queueFamilyIndexCount_ = 0, const uint32_t* pQueueFamilyIndices_ = nullptr )\r
+ : flags( flags_ )\r
+ , size( size_ )\r
+ , usage( usage_ )\r
+ , sharingMode( sharingMode_ )\r
+ , queueFamilyIndexCount( queueFamilyIndexCount_ )\r
+ , pQueueFamilyIndices( pQueueFamilyIndices_ )\r
+ {\r
+ }\r
+\r
+ BufferCreateInfo( VkBufferCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferCreateInfo ) );\r
+ }\r
+\r
+ BufferCreateInfo& operator=( VkBufferCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferCreateInfo ) );\r
+ return *this;\r
+ }\r
+ BufferCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCreateInfo& setFlags( BufferCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCreateInfo& setSize( DeviceSize size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCreateInfo& setUsage( BufferUsageFlags usage_ )\r
+ {\r
+ usage = usage_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCreateInfo& setSharingMode( SharingMode sharingMode_ )\r
+ {\r
+ sharingMode = sharingMode_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCreateInfo& setQueueFamilyIndexCount( uint32_t queueFamilyIndexCount_ )\r
+ {\r
+ queueFamilyIndexCount = queueFamilyIndexCount_;\r
+ return *this;\r
+ }\r
+\r
+ BufferCreateInfo& setPQueueFamilyIndices( const uint32_t* pQueueFamilyIndices_ )\r
+ {\r
+ pQueueFamilyIndices = pQueueFamilyIndices_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBufferCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBufferCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BufferCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( size == rhs.size )\r
+ && ( usage == rhs.usage )\r
+ && ( sharingMode == rhs.sharingMode )\r
+ && ( queueFamilyIndexCount == rhs.queueFamilyIndexCount )\r
+ && ( pQueueFamilyIndices == rhs.pQueueFamilyIndices );\r
+ }\r
+\r
+ bool operator!=( BufferCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBufferCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ BufferCreateFlags flags;\r
+ DeviceSize size;\r
+ BufferUsageFlags usage;\r
+ SharingMode sharingMode;\r
+ uint32_t queueFamilyIndexCount;\r
+ const uint32_t* pQueueFamilyIndices;\r
+ };\r
+ static_assert( sizeof( BufferCreateInfo ) == sizeof( VkBufferCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class ShaderStageFlagBits\r
+ {\r
+ eVertex = VK_SHADER_STAGE_VERTEX_BIT,\r
+ eTessellationControl = VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT,\r
+ eTessellationEvaluation = VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT,\r
+ eGeometry = VK_SHADER_STAGE_GEOMETRY_BIT,\r
+ eFragment = VK_SHADER_STAGE_FRAGMENT_BIT,\r
+ eCompute = VK_SHADER_STAGE_COMPUTE_BIT,\r
+ eAllGraphics = VK_SHADER_STAGE_ALL_GRAPHICS,\r
+ eAll = VK_SHADER_STAGE_ALL\r
+ };\r
+\r
+ using ShaderStageFlags = Flags<ShaderStageFlagBits, VkShaderStageFlags>;\r
+\r
+ VULKAN_HPP_INLINE ShaderStageFlags operator|( ShaderStageFlagBits bit0, ShaderStageFlagBits bit1 )\r
+ {\r
+ return ShaderStageFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ShaderStageFlags operator~( ShaderStageFlagBits bits )\r
+ {\r
+ return ~( ShaderStageFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ShaderStageFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ShaderStageFlagBits::eVertex) | VkFlags(ShaderStageFlagBits::eTessellationControl) | VkFlags(ShaderStageFlagBits::eTessellationEvaluation) | VkFlags(ShaderStageFlagBits::eGeometry) | VkFlags(ShaderStageFlagBits::eFragment) | VkFlags(ShaderStageFlagBits::eCompute) | VkFlags(ShaderStageFlagBits::eAllGraphics) | VkFlags(ShaderStageFlagBits::eAll)\r
+ };\r
+ };\r
+\r
+ struct DescriptorSetLayoutBinding\r
+ {\r
+ DescriptorSetLayoutBinding( uint32_t binding_ = 0, DescriptorType descriptorType_ = DescriptorType::eSampler, uint32_t descriptorCount_ = 0, ShaderStageFlags stageFlags_ = ShaderStageFlags(), const Sampler* pImmutableSamplers_ = nullptr )\r
+ : binding( binding_ )\r
+ , descriptorType( descriptorType_ )\r
+ , descriptorCount( descriptorCount_ )\r
+ , stageFlags( stageFlags_ )\r
+ , pImmutableSamplers( pImmutableSamplers_ )\r
+ {\r
+ }\r
+\r
+ DescriptorSetLayoutBinding( VkDescriptorSetLayoutBinding const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetLayoutBinding ) );\r
+ }\r
+\r
+ DescriptorSetLayoutBinding& operator=( VkDescriptorSetLayoutBinding const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetLayoutBinding ) );\r
+ return *this;\r
+ }\r
+ DescriptorSetLayoutBinding& setBinding( uint32_t binding_ )\r
+ {\r
+ binding = binding_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutBinding& setDescriptorType( DescriptorType descriptorType_ )\r
+ {\r
+ descriptorType = descriptorType_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutBinding& setDescriptorCount( uint32_t descriptorCount_ )\r
+ {\r
+ descriptorCount = descriptorCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutBinding& setStageFlags( ShaderStageFlags stageFlags_ )\r
+ {\r
+ stageFlags = stageFlags_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutBinding& setPImmutableSamplers( const Sampler* pImmutableSamplers_ )\r
+ {\r
+ pImmutableSamplers = pImmutableSamplers_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorSetLayoutBinding&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetLayoutBinding*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetLayoutBinding const& rhs ) const\r
+ {\r
+ return ( binding == rhs.binding )\r
+ && ( descriptorType == rhs.descriptorType )\r
+ && ( descriptorCount == rhs.descriptorCount )\r
+ && ( stageFlags == rhs.stageFlags )\r
+ && ( pImmutableSamplers == rhs.pImmutableSamplers );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetLayoutBinding const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t binding;\r
+ DescriptorType descriptorType;\r
+ uint32_t descriptorCount;\r
+ ShaderStageFlags stageFlags;\r
+ const Sampler* pImmutableSamplers;\r
+ };\r
+ static_assert( sizeof( DescriptorSetLayoutBinding ) == sizeof( VkDescriptorSetLayoutBinding ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineShaderStageCreateInfo\r
+ {\r
+ PipelineShaderStageCreateInfo( PipelineShaderStageCreateFlags flags_ = PipelineShaderStageCreateFlags(), ShaderStageFlagBits stage_ = ShaderStageFlagBits::eVertex, ShaderModule module_ = ShaderModule(), const char* pName_ = nullptr, const SpecializationInfo* pSpecializationInfo_ = nullptr )\r
+ : flags( flags_ )\r
+ , stage( stage_ )\r
+ , module( module_ )\r
+ , pName( pName_ )\r
+ , pSpecializationInfo( pSpecializationInfo_ )\r
+ {\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo( VkPipelineShaderStageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineShaderStageCreateInfo ) );\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo& operator=( VkPipelineShaderStageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineShaderStageCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineShaderStageCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo& setFlags( PipelineShaderStageCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo& setStage( ShaderStageFlagBits stage_ )\r
+ {\r
+ stage = stage_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo& setModule( ShaderModule module_ )\r
+ {\r
+ module = module_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo& setPName( const char* pName_ )\r
+ {\r
+ pName = pName_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineShaderStageCreateInfo& setPSpecializationInfo( const SpecializationInfo* pSpecializationInfo_ )\r
+ {\r
+ pSpecializationInfo = pSpecializationInfo_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineShaderStageCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineShaderStageCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineShaderStageCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( stage == rhs.stage )\r
+ && ( module == rhs.module )\r
+ && ( pName == rhs.pName )\r
+ && ( pSpecializationInfo == rhs.pSpecializationInfo );\r
+ }\r
+\r
+ bool operator!=( PipelineShaderStageCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineShaderStageCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineShaderStageCreateFlags flags;\r
+ ShaderStageFlagBits stage;\r
+ ShaderModule module;\r
+ const char* pName;\r
+ const SpecializationInfo* pSpecializationInfo;\r
+ };\r
+ static_assert( sizeof( PipelineShaderStageCreateInfo ) == sizeof( VkPipelineShaderStageCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PushConstantRange\r
+ {\r
+ PushConstantRange( ShaderStageFlags stageFlags_ = ShaderStageFlags(), uint32_t offset_ = 0, uint32_t size_ = 0 )\r
+ : stageFlags( stageFlags_ )\r
+ , offset( offset_ )\r
+ , size( size_ )\r
+ {\r
+ }\r
+\r
+ PushConstantRange( VkPushConstantRange const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PushConstantRange ) );\r
+ }\r
+\r
+ PushConstantRange& operator=( VkPushConstantRange const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PushConstantRange ) );\r
+ return *this;\r
+ }\r
+ PushConstantRange& setStageFlags( ShaderStageFlags stageFlags_ )\r
+ {\r
+ stageFlags = stageFlags_;\r
+ return *this;\r
+ }\r
+\r
+ PushConstantRange& setOffset( uint32_t offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ PushConstantRange& setSize( uint32_t size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPushConstantRange&() const\r
+ {\r
+ return *reinterpret_cast<const VkPushConstantRange*>(this);\r
+ }\r
+\r
+ bool operator==( PushConstantRange const& rhs ) const\r
+ {\r
+ return ( stageFlags == rhs.stageFlags )\r
+ && ( offset == rhs.offset )\r
+ && ( size == rhs.size );\r
+ }\r
+\r
+ bool operator!=( PushConstantRange const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ShaderStageFlags stageFlags;\r
+ uint32_t offset;\r
+ uint32_t size;\r
+ };\r
+ static_assert( sizeof( PushConstantRange ) == sizeof( VkPushConstantRange ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineLayoutCreateInfo\r
+ {\r
+ PipelineLayoutCreateInfo( PipelineLayoutCreateFlags flags_ = PipelineLayoutCreateFlags(), uint32_t setLayoutCount_ = 0, const DescriptorSetLayout* pSetLayouts_ = nullptr, uint32_t pushConstantRangeCount_ = 0, const PushConstantRange* pPushConstantRanges_ = nullptr )\r
+ : flags( flags_ )\r
+ , setLayoutCount( setLayoutCount_ )\r
+ , pSetLayouts( pSetLayouts_ )\r
+ , pushConstantRangeCount( pushConstantRangeCount_ )\r
+ , pPushConstantRanges( pPushConstantRanges_ )\r
+ {\r
+ }\r
+\r
+ PipelineLayoutCreateInfo( VkPipelineLayoutCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineLayoutCreateInfo ) );\r
+ }\r
+\r
+ PipelineLayoutCreateInfo& operator=( VkPipelineLayoutCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineLayoutCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineLayoutCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineLayoutCreateInfo& setFlags( PipelineLayoutCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineLayoutCreateInfo& setSetLayoutCount( uint32_t setLayoutCount_ )\r
+ {\r
+ setLayoutCount = setLayoutCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineLayoutCreateInfo& setPSetLayouts( const DescriptorSetLayout* pSetLayouts_ )\r
+ {\r
+ pSetLayouts = pSetLayouts_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineLayoutCreateInfo& setPushConstantRangeCount( uint32_t pushConstantRangeCount_ )\r
+ {\r
+ pushConstantRangeCount = pushConstantRangeCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineLayoutCreateInfo& setPPushConstantRanges( const PushConstantRange* pPushConstantRanges_ )\r
+ {\r
+ pPushConstantRanges = pPushConstantRanges_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineLayoutCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineLayoutCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineLayoutCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( setLayoutCount == rhs.setLayoutCount )\r
+ && ( pSetLayouts == rhs.pSetLayouts )\r
+ && ( pushConstantRangeCount == rhs.pushConstantRangeCount )\r
+ && ( pPushConstantRanges == rhs.pPushConstantRanges );\r
+ }\r
+\r
+ bool operator!=( PipelineLayoutCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineLayoutCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineLayoutCreateFlags flags;\r
+ uint32_t setLayoutCount;\r
+ const DescriptorSetLayout* pSetLayouts;\r
+ uint32_t pushConstantRangeCount;\r
+ const PushConstantRange* pPushConstantRanges;\r
+ };\r
+ static_assert( sizeof( PipelineLayoutCreateInfo ) == sizeof( VkPipelineLayoutCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct ShaderStatisticsInfoAMD\r
+ {\r
+ operator const VkShaderStatisticsInfoAMD&() const\r
+ {\r
+ return *reinterpret_cast<const VkShaderStatisticsInfoAMD*>(this);\r
+ }\r
+\r
+ bool operator==( ShaderStatisticsInfoAMD const& rhs ) const\r
+ {\r
+ return ( shaderStageMask == rhs.shaderStageMask )\r
+ && ( resourceUsage == rhs.resourceUsage )\r
+ && ( numPhysicalVgprs == rhs.numPhysicalVgprs )\r
+ && ( numPhysicalSgprs == rhs.numPhysicalSgprs )\r
+ && ( numAvailableVgprs == rhs.numAvailableVgprs )\r
+ && ( numAvailableSgprs == rhs.numAvailableSgprs )\r
+ && ( memcmp( computeWorkGroupSize, rhs.computeWorkGroupSize, 3 * sizeof( uint32_t ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( ShaderStatisticsInfoAMD const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ShaderStageFlags shaderStageMask;\r
+ ShaderResourceUsageAMD resourceUsage;\r
+ uint32_t numPhysicalVgprs;\r
+ uint32_t numPhysicalSgprs;\r
+ uint32_t numAvailableVgprs;\r
+ uint32_t numAvailableSgprs;\r
+ uint32_t computeWorkGroupSize[3];\r
+ };\r
+ static_assert( sizeof( ShaderStatisticsInfoAMD ) == sizeof( VkShaderStatisticsInfoAMD ), "struct and wrapper have different size!" );\r
+\r
+ enum class ImageUsageFlagBits\r
+ {\r
+ eTransferSrc = VK_IMAGE_USAGE_TRANSFER_SRC_BIT,\r
+ eTransferDst = VK_IMAGE_USAGE_TRANSFER_DST_BIT,\r
+ eSampled = VK_IMAGE_USAGE_SAMPLED_BIT,\r
+ eStorage = VK_IMAGE_USAGE_STORAGE_BIT,\r
+ eColorAttachment = VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,\r
+ eDepthStencilAttachment = VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT,\r
+ eTransientAttachment = VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT,\r
+ eInputAttachment = VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT\r
+ };\r
+\r
+ using ImageUsageFlags = Flags<ImageUsageFlagBits, VkImageUsageFlags>;\r
+\r
+ VULKAN_HPP_INLINE ImageUsageFlags operator|( ImageUsageFlagBits bit0, ImageUsageFlagBits bit1 )\r
+ {\r
+ return ImageUsageFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ImageUsageFlags operator~( ImageUsageFlagBits bits )\r
+ {\r
+ return ~( ImageUsageFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ImageUsageFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ImageUsageFlagBits::eTransferSrc) | VkFlags(ImageUsageFlagBits::eTransferDst) | VkFlags(ImageUsageFlagBits::eSampled) | VkFlags(ImageUsageFlagBits::eStorage) | VkFlags(ImageUsageFlagBits::eColorAttachment) | VkFlags(ImageUsageFlagBits::eDepthStencilAttachment) | VkFlags(ImageUsageFlagBits::eTransientAttachment) | VkFlags(ImageUsageFlagBits::eInputAttachment)\r
+ };\r
+ };\r
+\r
+ struct SharedPresentSurfaceCapabilitiesKHR\r
+ {\r
+ operator const VkSharedPresentSurfaceCapabilitiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSharedPresentSurfaceCapabilitiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( SharedPresentSurfaceCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( sharedPresentSupportedUsageFlags == rhs.sharedPresentSupportedUsageFlags );\r
+ }\r
+\r
+ bool operator!=( SharedPresentSurfaceCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSharedPresentSurfaceCapabilitiesKHR;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ ImageUsageFlags sharedPresentSupportedUsageFlags;\r
+ };\r
+ static_assert( sizeof( SharedPresentSurfaceCapabilitiesKHR ) == sizeof( VkSharedPresentSurfaceCapabilitiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageViewUsageCreateInfo\r
+ {\r
+ ImageViewUsageCreateInfo( ImageUsageFlags usage_ = ImageUsageFlags() )\r
+ : usage( usage_ )\r
+ {\r
+ }\r
+\r
+ ImageViewUsageCreateInfo( VkImageViewUsageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageViewUsageCreateInfo ) );\r
+ }\r
+\r
+ ImageViewUsageCreateInfo& operator=( VkImageViewUsageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageViewUsageCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ImageViewUsageCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewUsageCreateInfo& setUsage( ImageUsageFlags usage_ )\r
+ {\r
+ usage = usage_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageViewUsageCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageViewUsageCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ImageViewUsageCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( usage == rhs.usage );\r
+ }\r
+\r
+ bool operator!=( ImageViewUsageCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageViewUsageCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ImageUsageFlags usage;\r
+ };\r
+ static_assert( sizeof( ImageViewUsageCreateInfo ) == sizeof( VkImageViewUsageCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ImageViewUsageCreateInfoKHR = ImageViewUsageCreateInfo;\r
+\r
+ enum class ImageCreateFlagBits\r
+ {\r
+ eSparseBinding = VK_IMAGE_CREATE_SPARSE_BINDING_BIT,\r
+ eSparseResidency = VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT,\r
+ eSparseAliased = VK_IMAGE_CREATE_SPARSE_ALIASED_BIT,\r
+ eMutableFormat = VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT,\r
+ eCubeCompatible = VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT,\r
+ eAlias = VK_IMAGE_CREATE_ALIAS_BIT,\r
+ eAliasKHR = VK_IMAGE_CREATE_ALIAS_BIT,\r
+ eSplitInstanceBindRegions = VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT,\r
+ eSplitInstanceBindRegionsKHR = VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT,\r
+ e2DArrayCompatible = VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT,\r
+ e2DArrayCompatibleKHR = VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT,\r
+ eBlockTexelViewCompatible = VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT,\r
+ eBlockTexelViewCompatibleKHR = VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT,\r
+ eExtendedUsage = VK_IMAGE_CREATE_EXTENDED_USAGE_BIT,\r
+ eExtendedUsageKHR = VK_IMAGE_CREATE_EXTENDED_USAGE_BIT,\r
+ eProtected = VK_IMAGE_CREATE_PROTECTED_BIT,\r
+ eDisjoint = VK_IMAGE_CREATE_DISJOINT_BIT,\r
+ eDisjointKHR = VK_IMAGE_CREATE_DISJOINT_BIT,\r
+ eSampleLocationsCompatibleDepthEXT = VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT\r
+ };\r
+\r
+ using ImageCreateFlags = Flags<ImageCreateFlagBits, VkImageCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE ImageCreateFlags operator|( ImageCreateFlagBits bit0, ImageCreateFlagBits bit1 )\r
+ {\r
+ return ImageCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ImageCreateFlags operator~( ImageCreateFlagBits bits )\r
+ {\r
+ return ~( ImageCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ImageCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ImageCreateFlagBits::eSparseBinding) | VkFlags(ImageCreateFlagBits::eSparseResidency) | VkFlags(ImageCreateFlagBits::eSparseAliased) | VkFlags(ImageCreateFlagBits::eMutableFormat) | VkFlags(ImageCreateFlagBits::eCubeCompatible) | VkFlags(ImageCreateFlagBits::eAlias) | VkFlags(ImageCreateFlagBits::eSplitInstanceBindRegions) | VkFlags(ImageCreateFlagBits::e2DArrayCompatible) | VkFlags(ImageCreateFlagBits::eBlockTexelViewCompatible) | VkFlags(ImageCreateFlagBits::eExtendedUsage) | VkFlags(ImageCreateFlagBits::eProtected) | VkFlags(ImageCreateFlagBits::eDisjoint) | VkFlags(ImageCreateFlagBits::eSampleLocationsCompatibleDepthEXT)\r
+ };\r
+ };\r
+\r
+ struct PhysicalDeviceImageFormatInfo2\r
+ {\r
+ PhysicalDeviceImageFormatInfo2( Format format_ = Format::eUndefined, ImageType type_ = ImageType::e1D, ImageTiling tiling_ = ImageTiling::eOptimal, ImageUsageFlags usage_ = ImageUsageFlags(), ImageCreateFlags flags_ = ImageCreateFlags() )\r
+ : format( format_ )\r
+ , type( type_ )\r
+ , tiling( tiling_ )\r
+ , usage( usage_ )\r
+ , flags( flags_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2( VkPhysicalDeviceImageFormatInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceImageFormatInfo2 ) );\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2& operator=( VkPhysicalDeviceImageFormatInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceImageFormatInfo2 ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceImageFormatInfo2& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2& setType( ImageType type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2& setTiling( ImageTiling tiling_ )\r
+ {\r
+ tiling = tiling_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2& setUsage( ImageUsageFlags usage_ )\r
+ {\r
+ usage = usage_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceImageFormatInfo2& setFlags( ImageCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceImageFormatInfo2&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceImageFormatInfo2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( format == rhs.format )\r
+ && ( type == rhs.type )\r
+ && ( tiling == rhs.tiling )\r
+ && ( usage == rhs.usage )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceImageFormatInfo2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceImageFormatInfo2;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Format format;\r
+ ImageType type;\r
+ ImageTiling tiling;\r
+ ImageUsageFlags usage;\r
+ ImageCreateFlags flags;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceImageFormatInfo2 ) == sizeof( VkPhysicalDeviceImageFormatInfo2 ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceImageFormatInfo2KHR = PhysicalDeviceImageFormatInfo2;\r
+\r
+ enum class PipelineCreateFlagBits\r
+ {\r
+ eDisableOptimization = VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT,\r
+ eAllowDerivatives = VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT,\r
+ eDerivative = VK_PIPELINE_CREATE_DERIVATIVE_BIT,\r
+ eViewIndexFromDeviceIndex = VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT,\r
+ eViewIndexFromDeviceIndexKHR = VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT,\r
+ eDispatchBase = VK_PIPELINE_CREATE_DISPATCH_BASE,\r
+ eDispatchBaseKHR = VK_PIPELINE_CREATE_DISPATCH_BASE\r
+ };\r
+\r
+ using PipelineCreateFlags = Flags<PipelineCreateFlagBits, VkPipelineCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE PipelineCreateFlags operator|( PipelineCreateFlagBits bit0, PipelineCreateFlagBits bit1 )\r
+ {\r
+ return PipelineCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE PipelineCreateFlags operator~( PipelineCreateFlagBits bits )\r
+ {\r
+ return ~( PipelineCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<PipelineCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(PipelineCreateFlagBits::eDisableOptimization) | VkFlags(PipelineCreateFlagBits::eAllowDerivatives) | VkFlags(PipelineCreateFlagBits::eDerivative) | VkFlags(PipelineCreateFlagBits::eViewIndexFromDeviceIndex) | VkFlags(PipelineCreateFlagBits::eDispatchBase)\r
+ };\r
+ };\r
+\r
+ struct ComputePipelineCreateInfo\r
+ {\r
+ ComputePipelineCreateInfo( PipelineCreateFlags flags_ = PipelineCreateFlags(), PipelineShaderStageCreateInfo stage_ = PipelineShaderStageCreateInfo(), PipelineLayout layout_ = PipelineLayout(), Pipeline basePipelineHandle_ = Pipeline(), int32_t basePipelineIndex_ = 0 )\r
+ : flags( flags_ )\r
+ , stage( stage_ )\r
+ , layout( layout_ )\r
+ , basePipelineHandle( basePipelineHandle_ )\r
+ , basePipelineIndex( basePipelineIndex_ )\r
+ {\r
+ }\r
+\r
+ ComputePipelineCreateInfo( VkComputePipelineCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ComputePipelineCreateInfo ) );\r
+ }\r
+\r
+ ComputePipelineCreateInfo& operator=( VkComputePipelineCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ComputePipelineCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ComputePipelineCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ComputePipelineCreateInfo& setFlags( PipelineCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ComputePipelineCreateInfo& setStage( PipelineShaderStageCreateInfo stage_ )\r
+ {\r
+ stage = stage_;\r
+ return *this;\r
+ }\r
+\r
+ ComputePipelineCreateInfo& setLayout( PipelineLayout layout_ )\r
+ {\r
+ layout = layout_;\r
+ return *this;\r
+ }\r
+\r
+ ComputePipelineCreateInfo& setBasePipelineHandle( Pipeline basePipelineHandle_ )\r
+ {\r
+ basePipelineHandle = basePipelineHandle_;\r
+ return *this;\r
+ }\r
+\r
+ ComputePipelineCreateInfo& setBasePipelineIndex( int32_t basePipelineIndex_ )\r
+ {\r
+ basePipelineIndex = basePipelineIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkComputePipelineCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkComputePipelineCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ComputePipelineCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( stage == rhs.stage )\r
+ && ( layout == rhs.layout )\r
+ && ( basePipelineHandle == rhs.basePipelineHandle )\r
+ && ( basePipelineIndex == rhs.basePipelineIndex );\r
+ }\r
+\r
+ bool operator!=( ComputePipelineCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eComputePipelineCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineCreateFlags flags;\r
+ PipelineShaderStageCreateInfo stage;\r
+ PipelineLayout layout;\r
+ Pipeline basePipelineHandle;\r
+ int32_t basePipelineIndex;\r
+ };\r
+ static_assert( sizeof( ComputePipelineCreateInfo ) == sizeof( VkComputePipelineCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class ColorComponentFlagBits\r
+ {\r
+ eR = VK_COLOR_COMPONENT_R_BIT,\r
+ eG = VK_COLOR_COMPONENT_G_BIT,\r
+ eB = VK_COLOR_COMPONENT_B_BIT,\r
+ eA = VK_COLOR_COMPONENT_A_BIT\r
+ };\r
+\r
+ using ColorComponentFlags = Flags<ColorComponentFlagBits, VkColorComponentFlags>;\r
+\r
+ VULKAN_HPP_INLINE ColorComponentFlags operator|( ColorComponentFlagBits bit0, ColorComponentFlagBits bit1 )\r
+ {\r
+ return ColorComponentFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ColorComponentFlags operator~( ColorComponentFlagBits bits )\r
+ {\r
+ return ~( ColorComponentFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ColorComponentFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ColorComponentFlagBits::eR) | VkFlags(ColorComponentFlagBits::eG) | VkFlags(ColorComponentFlagBits::eB) | VkFlags(ColorComponentFlagBits::eA)\r
+ };\r
+ };\r
+\r
+ struct PipelineColorBlendAttachmentState\r
+ {\r
+ PipelineColorBlendAttachmentState( Bool32 blendEnable_ = 0, BlendFactor srcColorBlendFactor_ = BlendFactor::eZero, BlendFactor dstColorBlendFactor_ = BlendFactor::eZero, BlendOp colorBlendOp_ = BlendOp::eAdd, BlendFactor srcAlphaBlendFactor_ = BlendFactor::eZero, BlendFactor dstAlphaBlendFactor_ = BlendFactor::eZero, BlendOp alphaBlendOp_ = BlendOp::eAdd, ColorComponentFlags colorWriteMask_ = ColorComponentFlags() )\r
+ : blendEnable( blendEnable_ )\r
+ , srcColorBlendFactor( srcColorBlendFactor_ )\r
+ , dstColorBlendFactor( dstColorBlendFactor_ )\r
+ , colorBlendOp( colorBlendOp_ )\r
+ , srcAlphaBlendFactor( srcAlphaBlendFactor_ )\r
+ , dstAlphaBlendFactor( dstAlphaBlendFactor_ )\r
+ , alphaBlendOp( alphaBlendOp_ )\r
+ , colorWriteMask( colorWriteMask_ )\r
+ {\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState( VkPipelineColorBlendAttachmentState const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineColorBlendAttachmentState ) );\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& operator=( VkPipelineColorBlendAttachmentState const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineColorBlendAttachmentState ) );\r
+ return *this;\r
+ }\r
+ PipelineColorBlendAttachmentState& setBlendEnable( Bool32 blendEnable_ )\r
+ {\r
+ blendEnable = blendEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setSrcColorBlendFactor( BlendFactor srcColorBlendFactor_ )\r
+ {\r
+ srcColorBlendFactor = srcColorBlendFactor_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setDstColorBlendFactor( BlendFactor dstColorBlendFactor_ )\r
+ {\r
+ dstColorBlendFactor = dstColorBlendFactor_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setColorBlendOp( BlendOp colorBlendOp_ )\r
+ {\r
+ colorBlendOp = colorBlendOp_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setSrcAlphaBlendFactor( BlendFactor srcAlphaBlendFactor_ )\r
+ {\r
+ srcAlphaBlendFactor = srcAlphaBlendFactor_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setDstAlphaBlendFactor( BlendFactor dstAlphaBlendFactor_ )\r
+ {\r
+ dstAlphaBlendFactor = dstAlphaBlendFactor_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setAlphaBlendOp( BlendOp alphaBlendOp_ )\r
+ {\r
+ alphaBlendOp = alphaBlendOp_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAttachmentState& setColorWriteMask( ColorComponentFlags colorWriteMask_ )\r
+ {\r
+ colorWriteMask = colorWriteMask_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineColorBlendAttachmentState&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineColorBlendAttachmentState*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineColorBlendAttachmentState const& rhs ) const\r
+ {\r
+ return ( blendEnable == rhs.blendEnable )\r
+ && ( srcColorBlendFactor == rhs.srcColorBlendFactor )\r
+ && ( dstColorBlendFactor == rhs.dstColorBlendFactor )\r
+ && ( colorBlendOp == rhs.colorBlendOp )\r
+ && ( srcAlphaBlendFactor == rhs.srcAlphaBlendFactor )\r
+ && ( dstAlphaBlendFactor == rhs.dstAlphaBlendFactor )\r
+ && ( alphaBlendOp == rhs.alphaBlendOp )\r
+ && ( colorWriteMask == rhs.colorWriteMask );\r
+ }\r
+\r
+ bool operator!=( PipelineColorBlendAttachmentState const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Bool32 blendEnable;\r
+ BlendFactor srcColorBlendFactor;\r
+ BlendFactor dstColorBlendFactor;\r
+ BlendOp colorBlendOp;\r
+ BlendFactor srcAlphaBlendFactor;\r
+ BlendFactor dstAlphaBlendFactor;\r
+ BlendOp alphaBlendOp;\r
+ ColorComponentFlags colorWriteMask;\r
+ };\r
+ static_assert( sizeof( PipelineColorBlendAttachmentState ) == sizeof( VkPipelineColorBlendAttachmentState ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineColorBlendStateCreateInfo\r
+ {\r
+ PipelineColorBlendStateCreateInfo( PipelineColorBlendStateCreateFlags flags_ = PipelineColorBlendStateCreateFlags(), Bool32 logicOpEnable_ = 0, LogicOp logicOp_ = LogicOp::eClear, uint32_t attachmentCount_ = 0, const PipelineColorBlendAttachmentState* pAttachments_ = nullptr, std::array<float,4> const& blendConstants_ = { { 0, 0, 0, 0 } } )\r
+ : flags( flags_ )\r
+ , logicOpEnable( logicOpEnable_ )\r
+ , logicOp( logicOp_ )\r
+ , attachmentCount( attachmentCount_ )\r
+ , pAttachments( pAttachments_ )\r
+ {\r
+ memcpy( &blendConstants, blendConstants_.data(), 4 * sizeof( float ) );\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo( VkPipelineColorBlendStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineColorBlendStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& operator=( VkPipelineColorBlendStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineColorBlendStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineColorBlendStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& setFlags( PipelineColorBlendStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& setLogicOpEnable( Bool32 logicOpEnable_ )\r
+ {\r
+ logicOpEnable = logicOpEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& setLogicOp( LogicOp logicOp_ )\r
+ {\r
+ logicOp = logicOp_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& setAttachmentCount( uint32_t attachmentCount_ )\r
+ {\r
+ attachmentCount = attachmentCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& setPAttachments( const PipelineColorBlendAttachmentState* pAttachments_ )\r
+ {\r
+ pAttachments = pAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendStateCreateInfo& setBlendConstants( std::array<float,4> blendConstants_ )\r
+ {\r
+ memcpy( &blendConstants, blendConstants_.data(), 4 * sizeof( float ) );\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineColorBlendStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineColorBlendStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineColorBlendStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( logicOpEnable == rhs.logicOpEnable )\r
+ && ( logicOp == rhs.logicOp )\r
+ && ( attachmentCount == rhs.attachmentCount )\r
+ && ( pAttachments == rhs.pAttachments )\r
+ && ( memcmp( blendConstants, rhs.blendConstants, 4 * sizeof( float ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( PipelineColorBlendStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineColorBlendStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineColorBlendStateCreateFlags flags;\r
+ Bool32 logicOpEnable;\r
+ LogicOp logicOp;\r
+ uint32_t attachmentCount;\r
+ const PipelineColorBlendAttachmentState* pAttachments;\r
+ float blendConstants[4];\r
+ };\r
+ static_assert( sizeof( PipelineColorBlendStateCreateInfo ) == sizeof( VkPipelineColorBlendStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class FenceCreateFlagBits\r
+ {\r
+ eSignaled = VK_FENCE_CREATE_SIGNALED_BIT\r
+ };\r
+\r
+ using FenceCreateFlags = Flags<FenceCreateFlagBits, VkFenceCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE FenceCreateFlags operator|( FenceCreateFlagBits bit0, FenceCreateFlagBits bit1 )\r
+ {\r
+ return FenceCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE FenceCreateFlags operator~( FenceCreateFlagBits bits )\r
+ {\r
+ return ~( FenceCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<FenceCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(FenceCreateFlagBits::eSignaled)\r
+ };\r
+ };\r
+\r
+ struct FenceCreateInfo\r
+ {\r
+ FenceCreateInfo( FenceCreateFlags flags_ = FenceCreateFlags() )\r
+ : flags( flags_ )\r
+ {\r
+ }\r
+\r
+ FenceCreateInfo( VkFenceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FenceCreateInfo ) );\r
+ }\r
+\r
+ FenceCreateInfo& operator=( VkFenceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FenceCreateInfo ) );\r
+ return *this;\r
+ }\r
+ FenceCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ FenceCreateInfo& setFlags( FenceCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkFenceCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkFenceCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( FenceCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( FenceCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eFenceCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ FenceCreateFlags flags;\r
+ };\r
+ static_assert( sizeof( FenceCreateInfo ) == sizeof( VkFenceCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class FormatFeatureFlagBits\r
+ {\r
+ eSampledImage = VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT,\r
+ eStorageImage = VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT,\r
+ eStorageImageAtomic = VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT,\r
+ eUniformTexelBuffer = VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT,\r
+ eStorageTexelBuffer = VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT,\r
+ eStorageTexelBufferAtomic = VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT,\r
+ eVertexBuffer = VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT,\r
+ eColorAttachment = VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT,\r
+ eColorAttachmentBlend = VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT,\r
+ eDepthStencilAttachment = VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT,\r
+ eBlitSrc = VK_FORMAT_FEATURE_BLIT_SRC_BIT,\r
+ eBlitDst = VK_FORMAT_FEATURE_BLIT_DST_BIT,\r
+ eSampledImageFilterLinear = VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT,\r
+ eTransferSrc = VK_FORMAT_FEATURE_TRANSFER_SRC_BIT,\r
+ eTransferSrcKHR = VK_FORMAT_FEATURE_TRANSFER_SRC_BIT,\r
+ eTransferDst = VK_FORMAT_FEATURE_TRANSFER_DST_BIT,\r
+ eTransferDstKHR = VK_FORMAT_FEATURE_TRANSFER_DST_BIT,\r
+ eMidpointChromaSamples = VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT,\r
+ eMidpointChromaSamplesKHR = VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT,\r
+ eSampledImageYcbcrConversionLinearFilter = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT,\r
+ eSampledImageYcbcrConversionLinearFilterKHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT,\r
+ eSampledImageYcbcrConversionSeparateReconstructionFilter = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT,\r
+ eSampledImageYcbcrConversionSeparateReconstructionFilterKHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT,\r
+ eSampledImageYcbcrConversionChromaReconstructionExplicit = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT,\r
+ eSampledImageYcbcrConversionChromaReconstructionExplicitKHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT,\r
+ eSampledImageYcbcrConversionChromaReconstructionExplicitForceable = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT,\r
+ eSampledImageYcbcrConversionChromaReconstructionExplicitForceableKHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT,\r
+ eDisjoint = VK_FORMAT_FEATURE_DISJOINT_BIT,\r
+ eDisjointKHR = VK_FORMAT_FEATURE_DISJOINT_BIT,\r
+ eCositedChromaSamples = VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT,\r
+ eCositedChromaSamplesKHR = VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT,\r
+ eSampledImageFilterCubicIMG = VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG,\r
+ eSampledImageFilterMinmaxEXT = VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_MINMAX_BIT_EXT\r
+ };\r
+\r
+ using FormatFeatureFlags = Flags<FormatFeatureFlagBits, VkFormatFeatureFlags>;\r
+\r
+ VULKAN_HPP_INLINE FormatFeatureFlags operator|( FormatFeatureFlagBits bit0, FormatFeatureFlagBits bit1 )\r
+ {\r
+ return FormatFeatureFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE FormatFeatureFlags operator~( FormatFeatureFlagBits bits )\r
+ {\r
+ return ~( FormatFeatureFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<FormatFeatureFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(FormatFeatureFlagBits::eSampledImage) | VkFlags(FormatFeatureFlagBits::eStorageImage) | VkFlags(FormatFeatureFlagBits::eStorageImageAtomic) | VkFlags(FormatFeatureFlagBits::eUniformTexelBuffer) | VkFlags(FormatFeatureFlagBits::eStorageTexelBuffer) | VkFlags(FormatFeatureFlagBits::eStorageTexelBufferAtomic) | VkFlags(FormatFeatureFlagBits::eVertexBuffer) | VkFlags(FormatFeatureFlagBits::eColorAttachment) | VkFlags(FormatFeatureFlagBits::eColorAttachmentBlend) | VkFlags(FormatFeatureFlagBits::eDepthStencilAttachment) | VkFlags(FormatFeatureFlagBits::eBlitSrc) | VkFlags(FormatFeatureFlagBits::eBlitDst) | VkFlags(FormatFeatureFlagBits::eSampledImageFilterLinear) | VkFlags(FormatFeatureFlagBits::eTransferSrc) | VkFlags(FormatFeatureFlagBits::eTransferDst) | VkFlags(FormatFeatureFlagBits::eMidpointChromaSamples) | VkFlags(FormatFeatureFlagBits::eSampledImageYcbcrConversionLinearFilter) | VkFlags(FormatFeatureFlagBits::eSampledImageYcbcrConversionSeparateReconstructionFilter) | VkFlags(FormatFeatureFlagBits::eSampledImageYcbcrConversionChromaReconstructionExplicit) | VkFlags(FormatFeatureFlagBits::eSampledImageYcbcrConversionChromaReconstructionExplicitForceable) | VkFlags(FormatFeatureFlagBits::eDisjoint) | VkFlags(FormatFeatureFlagBits::eCositedChromaSamples) | VkFlags(FormatFeatureFlagBits::eSampledImageFilterCubicIMG) | VkFlags(FormatFeatureFlagBits::eSampledImageFilterMinmaxEXT)\r
+ };\r
+ };\r
+\r
+ struct FormatProperties\r
+ {\r
+ operator const VkFormatProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkFormatProperties*>(this);\r
+ }\r
+\r
+ bool operator==( FormatProperties const& rhs ) const\r
+ {\r
+ return ( linearTilingFeatures == rhs.linearTilingFeatures )\r
+ && ( optimalTilingFeatures == rhs.optimalTilingFeatures )\r
+ && ( bufferFeatures == rhs.bufferFeatures );\r
+ }\r
+\r
+ bool operator!=( FormatProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ FormatFeatureFlags linearTilingFeatures;\r
+ FormatFeatureFlags optimalTilingFeatures;\r
+ FormatFeatureFlags bufferFeatures;\r
+ };\r
+ static_assert( sizeof( FormatProperties ) == sizeof( VkFormatProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct FormatProperties2\r
+ {\r
+ operator const VkFormatProperties2&() const\r
+ {\r
+ return *reinterpret_cast<const VkFormatProperties2*>(this);\r
+ }\r
+\r
+ bool operator==( FormatProperties2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( formatProperties == rhs.formatProperties );\r
+ }\r
+\r
+ bool operator!=( FormatProperties2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eFormatProperties2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ FormatProperties formatProperties;\r
+ };\r
+ static_assert( sizeof( FormatProperties2 ) == sizeof( VkFormatProperties2 ), "struct and wrapper have different size!" );\r
+\r
+ using FormatProperties2KHR = FormatProperties2;\r
+\r
+ enum class QueryControlFlagBits\r
+ {\r
+ ePrecise = VK_QUERY_CONTROL_PRECISE_BIT\r
+ };\r
+\r
+ using QueryControlFlags = Flags<QueryControlFlagBits, VkQueryControlFlags>;\r
+\r
+ VULKAN_HPP_INLINE QueryControlFlags operator|( QueryControlFlagBits bit0, QueryControlFlagBits bit1 )\r
+ {\r
+ return QueryControlFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE QueryControlFlags operator~( QueryControlFlagBits bits )\r
+ {\r
+ return ~( QueryControlFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<QueryControlFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(QueryControlFlagBits::ePrecise)\r
+ };\r
+ };\r
+\r
+ enum class QueryResultFlagBits\r
+ {\r
+ e64 = VK_QUERY_RESULT_64_BIT,\r
+ eWait = VK_QUERY_RESULT_WAIT_BIT,\r
+ eWithAvailability = VK_QUERY_RESULT_WITH_AVAILABILITY_BIT,\r
+ ePartial = VK_QUERY_RESULT_PARTIAL_BIT\r
+ };\r
+\r
+ using QueryResultFlags = Flags<QueryResultFlagBits, VkQueryResultFlags>;\r
+\r
+ VULKAN_HPP_INLINE QueryResultFlags operator|( QueryResultFlagBits bit0, QueryResultFlagBits bit1 )\r
+ {\r
+ return QueryResultFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE QueryResultFlags operator~( QueryResultFlagBits bits )\r
+ {\r
+ return ~( QueryResultFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<QueryResultFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(QueryResultFlagBits::e64) | VkFlags(QueryResultFlagBits::eWait) | VkFlags(QueryResultFlagBits::eWithAvailability) | VkFlags(QueryResultFlagBits::ePartial)\r
+ };\r
+ };\r
+\r
+ enum class CommandBufferUsageFlagBits\r
+ {\r
+ eOneTimeSubmit = VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT,\r
+ eRenderPassContinue = VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT,\r
+ eSimultaneousUse = VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT\r
+ };\r
+\r
+ using CommandBufferUsageFlags = Flags<CommandBufferUsageFlagBits, VkCommandBufferUsageFlags>;\r
+\r
+ VULKAN_HPP_INLINE CommandBufferUsageFlags operator|( CommandBufferUsageFlagBits bit0, CommandBufferUsageFlagBits bit1 )\r
+ {\r
+ return CommandBufferUsageFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE CommandBufferUsageFlags operator~( CommandBufferUsageFlagBits bits )\r
+ {\r
+ return ~( CommandBufferUsageFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<CommandBufferUsageFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(CommandBufferUsageFlagBits::eOneTimeSubmit) | VkFlags(CommandBufferUsageFlagBits::eRenderPassContinue) | VkFlags(CommandBufferUsageFlagBits::eSimultaneousUse)\r
+ };\r
+ };\r
+\r
+ enum class QueryPipelineStatisticFlagBits\r
+ {\r
+ eInputAssemblyVertices = VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT,\r
+ eInputAssemblyPrimitives = VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT,\r
+ eVertexShaderInvocations = VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT,\r
+ eGeometryShaderInvocations = VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT,\r
+ eGeometryShaderPrimitives = VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT,\r
+ eClippingInvocations = VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT,\r
+ eClippingPrimitives = VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT,\r
+ eFragmentShaderInvocations = VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT,\r
+ eTessellationControlShaderPatches = VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT,\r
+ eTessellationEvaluationShaderInvocations = VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT,\r
+ eComputeShaderInvocations = VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT\r
+ };\r
+\r
+ using QueryPipelineStatisticFlags = Flags<QueryPipelineStatisticFlagBits, VkQueryPipelineStatisticFlags>;\r
+\r
+ VULKAN_HPP_INLINE QueryPipelineStatisticFlags operator|( QueryPipelineStatisticFlagBits bit0, QueryPipelineStatisticFlagBits bit1 )\r
+ {\r
+ return QueryPipelineStatisticFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE QueryPipelineStatisticFlags operator~( QueryPipelineStatisticFlagBits bits )\r
+ {\r
+ return ~( QueryPipelineStatisticFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<QueryPipelineStatisticFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(QueryPipelineStatisticFlagBits::eInputAssemblyVertices) | VkFlags(QueryPipelineStatisticFlagBits::eInputAssemblyPrimitives) | VkFlags(QueryPipelineStatisticFlagBits::eVertexShaderInvocations) | VkFlags(QueryPipelineStatisticFlagBits::eGeometryShaderInvocations) | VkFlags(QueryPipelineStatisticFlagBits::eGeometryShaderPrimitives) | VkFlags(QueryPipelineStatisticFlagBits::eClippingInvocations) | VkFlags(QueryPipelineStatisticFlagBits::eClippingPrimitives) | VkFlags(QueryPipelineStatisticFlagBits::eFragmentShaderInvocations) | VkFlags(QueryPipelineStatisticFlagBits::eTessellationControlShaderPatches) | VkFlags(QueryPipelineStatisticFlagBits::eTessellationEvaluationShaderInvocations) | VkFlags(QueryPipelineStatisticFlagBits::eComputeShaderInvocations)\r
+ };\r
+ };\r
+\r
+ struct CommandBufferInheritanceInfo\r
+ {\r
+ CommandBufferInheritanceInfo( RenderPass renderPass_ = RenderPass(), uint32_t subpass_ = 0, Framebuffer framebuffer_ = Framebuffer(), Bool32 occlusionQueryEnable_ = 0, QueryControlFlags queryFlags_ = QueryControlFlags(), QueryPipelineStatisticFlags pipelineStatistics_ = QueryPipelineStatisticFlags() )\r
+ : renderPass( renderPass_ )\r
+ , subpass( subpass_ )\r
+ , framebuffer( framebuffer_ )\r
+ , occlusionQueryEnable( occlusionQueryEnable_ )\r
+ , queryFlags( queryFlags_ )\r
+ , pipelineStatistics( pipelineStatistics_ )\r
+ {\r
+ }\r
+\r
+ CommandBufferInheritanceInfo( VkCommandBufferInheritanceInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandBufferInheritanceInfo ) );\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& operator=( VkCommandBufferInheritanceInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandBufferInheritanceInfo ) );\r
+ return *this;\r
+ }\r
+ CommandBufferInheritanceInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& setRenderPass( RenderPass renderPass_ )\r
+ {\r
+ renderPass = renderPass_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& setSubpass( uint32_t subpass_ )\r
+ {\r
+ subpass = subpass_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& setFramebuffer( Framebuffer framebuffer_ )\r
+ {\r
+ framebuffer = framebuffer_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& setOcclusionQueryEnable( Bool32 occlusionQueryEnable_ )\r
+ {\r
+ occlusionQueryEnable = occlusionQueryEnable_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& setQueryFlags( QueryControlFlags queryFlags_ )\r
+ {\r
+ queryFlags = queryFlags_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferInheritanceInfo& setPipelineStatistics( QueryPipelineStatisticFlags pipelineStatistics_ )\r
+ {\r
+ pipelineStatistics = pipelineStatistics_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCommandBufferInheritanceInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkCommandBufferInheritanceInfo*>(this);\r
+ }\r
+\r
+ bool operator==( CommandBufferInheritanceInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( renderPass == rhs.renderPass )\r
+ && ( subpass == rhs.subpass )\r
+ && ( framebuffer == rhs.framebuffer )\r
+ && ( occlusionQueryEnable == rhs.occlusionQueryEnable )\r
+ && ( queryFlags == rhs.queryFlags )\r
+ && ( pipelineStatistics == rhs.pipelineStatistics );\r
+ }\r
+\r
+ bool operator!=( CommandBufferInheritanceInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCommandBufferInheritanceInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ RenderPass renderPass;\r
+ uint32_t subpass;\r
+ Framebuffer framebuffer;\r
+ Bool32 occlusionQueryEnable;\r
+ QueryControlFlags queryFlags;\r
+ QueryPipelineStatisticFlags pipelineStatistics;\r
+ };\r
+ static_assert( sizeof( CommandBufferInheritanceInfo ) == sizeof( VkCommandBufferInheritanceInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct CommandBufferBeginInfo\r
+ {\r
+ CommandBufferBeginInfo( CommandBufferUsageFlags flags_ = CommandBufferUsageFlags(), const CommandBufferInheritanceInfo* pInheritanceInfo_ = nullptr )\r
+ : flags( flags_ )\r
+ , pInheritanceInfo( pInheritanceInfo_ )\r
+ {\r
+ }\r
+\r
+ CommandBufferBeginInfo( VkCommandBufferBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandBufferBeginInfo ) );\r
+ }\r
+\r
+ CommandBufferBeginInfo& operator=( VkCommandBufferBeginInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandBufferBeginInfo ) );\r
+ return *this;\r
+ }\r
+ CommandBufferBeginInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferBeginInfo& setFlags( CommandBufferUsageFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ CommandBufferBeginInfo& setPInheritanceInfo( const CommandBufferInheritanceInfo* pInheritanceInfo_ )\r
+ {\r
+ pInheritanceInfo = pInheritanceInfo_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCommandBufferBeginInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkCommandBufferBeginInfo*>(this);\r
+ }\r
+\r
+ bool operator==( CommandBufferBeginInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( pInheritanceInfo == rhs.pInheritanceInfo );\r
+ }\r
+\r
+ bool operator!=( CommandBufferBeginInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCommandBufferBeginInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ CommandBufferUsageFlags flags;\r
+ const CommandBufferInheritanceInfo* pInheritanceInfo;\r
+ };\r
+ static_assert( sizeof( CommandBufferBeginInfo ) == sizeof( VkCommandBufferBeginInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct QueryPoolCreateInfo\r
+ {\r
+ QueryPoolCreateInfo( QueryPoolCreateFlags flags_ = QueryPoolCreateFlags(), QueryType queryType_ = QueryType::eOcclusion, uint32_t queryCount_ = 0, QueryPipelineStatisticFlags pipelineStatistics_ = QueryPipelineStatisticFlags() )\r
+ : flags( flags_ )\r
+ , queryType( queryType_ )\r
+ , queryCount( queryCount_ )\r
+ , pipelineStatistics( pipelineStatistics_ )\r
+ {\r
+ }\r
+\r
+ QueryPoolCreateInfo( VkQueryPoolCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( QueryPoolCreateInfo ) );\r
+ }\r
+\r
+ QueryPoolCreateInfo& operator=( VkQueryPoolCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( QueryPoolCreateInfo ) );\r
+ return *this;\r
+ }\r
+ QueryPoolCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ QueryPoolCreateInfo& setFlags( QueryPoolCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ QueryPoolCreateInfo& setQueryType( QueryType queryType_ )\r
+ {\r
+ queryType = queryType_;\r
+ return *this;\r
+ }\r
+\r
+ QueryPoolCreateInfo& setQueryCount( uint32_t queryCount_ )\r
+ {\r
+ queryCount = queryCount_;\r
+ return *this;\r
+ }\r
+\r
+ QueryPoolCreateInfo& setPipelineStatistics( QueryPipelineStatisticFlags pipelineStatistics_ )\r
+ {\r
+ pipelineStatistics = pipelineStatistics_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkQueryPoolCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkQueryPoolCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( QueryPoolCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( queryType == rhs.queryType )\r
+ && ( queryCount == rhs.queryCount )\r
+ && ( pipelineStatistics == rhs.pipelineStatistics );\r
+ }\r
+\r
+ bool operator!=( QueryPoolCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eQueryPoolCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ QueryPoolCreateFlags flags;\r
+ QueryType queryType;\r
+ uint32_t queryCount;\r
+ QueryPipelineStatisticFlags pipelineStatistics;\r
+ };\r
+ static_assert( sizeof( QueryPoolCreateInfo ) == sizeof( VkQueryPoolCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class ImageAspectFlagBits\r
+ {\r
+ eColor = VK_IMAGE_ASPECT_COLOR_BIT,\r
+ eDepth = VK_IMAGE_ASPECT_DEPTH_BIT,\r
+ eStencil = VK_IMAGE_ASPECT_STENCIL_BIT,\r
+ eMetadata = VK_IMAGE_ASPECT_METADATA_BIT,\r
+ ePlane0 = VK_IMAGE_ASPECT_PLANE_0_BIT,\r
+ ePlane0KHR = VK_IMAGE_ASPECT_PLANE_0_BIT,\r
+ ePlane1 = VK_IMAGE_ASPECT_PLANE_1_BIT,\r
+ ePlane1KHR = VK_IMAGE_ASPECT_PLANE_1_BIT,\r
+ ePlane2 = VK_IMAGE_ASPECT_PLANE_2_BIT,\r
+ ePlane2KHR = VK_IMAGE_ASPECT_PLANE_2_BIT\r
+ };\r
+\r
+ using ImageAspectFlags = Flags<ImageAspectFlagBits, VkImageAspectFlags>;\r
+\r
+ VULKAN_HPP_INLINE ImageAspectFlags operator|( ImageAspectFlagBits bit0, ImageAspectFlagBits bit1 )\r
+ {\r
+ return ImageAspectFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ImageAspectFlags operator~( ImageAspectFlagBits bits )\r
+ {\r
+ return ~( ImageAspectFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ImageAspectFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ImageAspectFlagBits::eColor) | VkFlags(ImageAspectFlagBits::eDepth) | VkFlags(ImageAspectFlagBits::eStencil) | VkFlags(ImageAspectFlagBits::eMetadata) | VkFlags(ImageAspectFlagBits::ePlane0) | VkFlags(ImageAspectFlagBits::ePlane1) | VkFlags(ImageAspectFlagBits::ePlane2)\r
+ };\r
+ };\r
+\r
+ struct ImageSubresource\r
+ {\r
+ ImageSubresource( ImageAspectFlags aspectMask_ = ImageAspectFlags(), uint32_t mipLevel_ = 0, uint32_t arrayLayer_ = 0 )\r
+ : aspectMask( aspectMask_ )\r
+ , mipLevel( mipLevel_ )\r
+ , arrayLayer( arrayLayer_ )\r
+ {\r
+ }\r
+\r
+ ImageSubresource( VkImageSubresource const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSubresource ) );\r
+ }\r
+\r
+ ImageSubresource& operator=( VkImageSubresource const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSubresource ) );\r
+ return *this;\r
+ }\r
+ ImageSubresource& setAspectMask( ImageAspectFlags aspectMask_ )\r
+ {\r
+ aspectMask = aspectMask_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresource& setMipLevel( uint32_t mipLevel_ )\r
+ {\r
+ mipLevel = mipLevel_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresource& setArrayLayer( uint32_t arrayLayer_ )\r
+ {\r
+ arrayLayer = arrayLayer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageSubresource&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageSubresource*>(this);\r
+ }\r
+\r
+ bool operator==( ImageSubresource const& rhs ) const\r
+ {\r
+ return ( aspectMask == rhs.aspectMask )\r
+ && ( mipLevel == rhs.mipLevel )\r
+ && ( arrayLayer == rhs.arrayLayer );\r
+ }\r
+\r
+ bool operator!=( ImageSubresource const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageAspectFlags aspectMask;\r
+ uint32_t mipLevel;\r
+ uint32_t arrayLayer;\r
+ };\r
+ static_assert( sizeof( ImageSubresource ) == sizeof( VkImageSubresource ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageSubresourceLayers\r
+ {\r
+ ImageSubresourceLayers( ImageAspectFlags aspectMask_ = ImageAspectFlags(), uint32_t mipLevel_ = 0, uint32_t baseArrayLayer_ = 0, uint32_t layerCount_ = 0 )\r
+ : aspectMask( aspectMask_ )\r
+ , mipLevel( mipLevel_ )\r
+ , baseArrayLayer( baseArrayLayer_ )\r
+ , layerCount( layerCount_ )\r
+ {\r
+ }\r
+\r
+ ImageSubresourceLayers( VkImageSubresourceLayers const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSubresourceLayers ) );\r
+ }\r
+\r
+ ImageSubresourceLayers& operator=( VkImageSubresourceLayers const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSubresourceLayers ) );\r
+ return *this;\r
+ }\r
+ ImageSubresourceLayers& setAspectMask( ImageAspectFlags aspectMask_ )\r
+ {\r
+ aspectMask = aspectMask_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceLayers& setMipLevel( uint32_t mipLevel_ )\r
+ {\r
+ mipLevel = mipLevel_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceLayers& setBaseArrayLayer( uint32_t baseArrayLayer_ )\r
+ {\r
+ baseArrayLayer = baseArrayLayer_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceLayers& setLayerCount( uint32_t layerCount_ )\r
+ {\r
+ layerCount = layerCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageSubresourceLayers&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageSubresourceLayers*>(this);\r
+ }\r
+\r
+ bool operator==( ImageSubresourceLayers const& rhs ) const\r
+ {\r
+ return ( aspectMask == rhs.aspectMask )\r
+ && ( mipLevel == rhs.mipLevel )\r
+ && ( baseArrayLayer == rhs.baseArrayLayer )\r
+ && ( layerCount == rhs.layerCount );\r
+ }\r
+\r
+ bool operator!=( ImageSubresourceLayers const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageAspectFlags aspectMask;\r
+ uint32_t mipLevel;\r
+ uint32_t baseArrayLayer;\r
+ uint32_t layerCount;\r
+ };\r
+ static_assert( sizeof( ImageSubresourceLayers ) == sizeof( VkImageSubresourceLayers ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageSubresourceRange\r
+ {\r
+ ImageSubresourceRange( ImageAspectFlags aspectMask_ = ImageAspectFlags(), uint32_t baseMipLevel_ = 0, uint32_t levelCount_ = 0, uint32_t baseArrayLayer_ = 0, uint32_t layerCount_ = 0 )\r
+ : aspectMask( aspectMask_ )\r
+ , baseMipLevel( baseMipLevel_ )\r
+ , levelCount( levelCount_ )\r
+ , baseArrayLayer( baseArrayLayer_ )\r
+ , layerCount( layerCount_ )\r
+ {\r
+ }\r
+\r
+ ImageSubresourceRange( VkImageSubresourceRange const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSubresourceRange ) );\r
+ }\r
+\r
+ ImageSubresourceRange& operator=( VkImageSubresourceRange const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageSubresourceRange ) );\r
+ return *this;\r
+ }\r
+ ImageSubresourceRange& setAspectMask( ImageAspectFlags aspectMask_ )\r
+ {\r
+ aspectMask = aspectMask_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceRange& setBaseMipLevel( uint32_t baseMipLevel_ )\r
+ {\r
+ baseMipLevel = baseMipLevel_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceRange& setLevelCount( uint32_t levelCount_ )\r
+ {\r
+ levelCount = levelCount_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceRange& setBaseArrayLayer( uint32_t baseArrayLayer_ )\r
+ {\r
+ baseArrayLayer = baseArrayLayer_;\r
+ return *this;\r
+ }\r
+\r
+ ImageSubresourceRange& setLayerCount( uint32_t layerCount_ )\r
+ {\r
+ layerCount = layerCount_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageSubresourceRange&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageSubresourceRange*>(this);\r
+ }\r
+\r
+ bool operator==( ImageSubresourceRange const& rhs ) const\r
+ {\r
+ return ( aspectMask == rhs.aspectMask )\r
+ && ( baseMipLevel == rhs.baseMipLevel )\r
+ && ( levelCount == rhs.levelCount )\r
+ && ( baseArrayLayer == rhs.baseArrayLayer )\r
+ && ( layerCount == rhs.layerCount );\r
+ }\r
+\r
+ bool operator!=( ImageSubresourceRange const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageAspectFlags aspectMask;\r
+ uint32_t baseMipLevel;\r
+ uint32_t levelCount;\r
+ uint32_t baseArrayLayer;\r
+ uint32_t layerCount;\r
+ };\r
+ static_assert( sizeof( ImageSubresourceRange ) == sizeof( VkImageSubresourceRange ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageMemoryBarrier\r
+ {\r
+ ImageMemoryBarrier( AccessFlags srcAccessMask_ = AccessFlags(), AccessFlags dstAccessMask_ = AccessFlags(), ImageLayout oldLayout_ = ImageLayout::eUndefined, ImageLayout newLayout_ = ImageLayout::eUndefined, uint32_t srcQueueFamilyIndex_ = 0, uint32_t dstQueueFamilyIndex_ = 0, Image image_ = Image(), ImageSubresourceRange subresourceRange_ = ImageSubresourceRange() )\r
+ : srcAccessMask( srcAccessMask_ )\r
+ , dstAccessMask( dstAccessMask_ )\r
+ , oldLayout( oldLayout_ )\r
+ , newLayout( newLayout_ )\r
+ , srcQueueFamilyIndex( srcQueueFamilyIndex_ )\r
+ , dstQueueFamilyIndex( dstQueueFamilyIndex_ )\r
+ , image( image_ )\r
+ , subresourceRange( subresourceRange_ )\r
+ {\r
+ }\r
+\r
+ ImageMemoryBarrier( VkImageMemoryBarrier const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageMemoryBarrier ) );\r
+ }\r
+\r
+ ImageMemoryBarrier& operator=( VkImageMemoryBarrier const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageMemoryBarrier ) );\r
+ return *this;\r
+ }\r
+ ImageMemoryBarrier& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setSrcAccessMask( AccessFlags srcAccessMask_ )\r
+ {\r
+ srcAccessMask = srcAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setDstAccessMask( AccessFlags dstAccessMask_ )\r
+ {\r
+ dstAccessMask = dstAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setOldLayout( ImageLayout oldLayout_ )\r
+ {\r
+ oldLayout = oldLayout_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setNewLayout( ImageLayout newLayout_ )\r
+ {\r
+ newLayout = newLayout_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setSrcQueueFamilyIndex( uint32_t srcQueueFamilyIndex_ )\r
+ {\r
+ srcQueueFamilyIndex = srcQueueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setDstQueueFamilyIndex( uint32_t dstQueueFamilyIndex_ )\r
+ {\r
+ dstQueueFamilyIndex = dstQueueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ ImageMemoryBarrier& setSubresourceRange( ImageSubresourceRange subresourceRange_ )\r
+ {\r
+ subresourceRange = subresourceRange_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageMemoryBarrier&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageMemoryBarrier*>(this);\r
+ }\r
+\r
+ bool operator==( ImageMemoryBarrier const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( srcAccessMask == rhs.srcAccessMask )\r
+ && ( dstAccessMask == rhs.dstAccessMask )\r
+ && ( oldLayout == rhs.oldLayout )\r
+ && ( newLayout == rhs.newLayout )\r
+ && ( srcQueueFamilyIndex == rhs.srcQueueFamilyIndex )\r
+ && ( dstQueueFamilyIndex == rhs.dstQueueFamilyIndex )\r
+ && ( image == rhs.image )\r
+ && ( subresourceRange == rhs.subresourceRange );\r
+ }\r
+\r
+ bool operator!=( ImageMemoryBarrier const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageMemoryBarrier;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ AccessFlags srcAccessMask;\r
+ AccessFlags dstAccessMask;\r
+ ImageLayout oldLayout;\r
+ ImageLayout newLayout;\r
+ uint32_t srcQueueFamilyIndex;\r
+ uint32_t dstQueueFamilyIndex;\r
+ Image image;\r
+ ImageSubresourceRange subresourceRange;\r
+ };\r
+ static_assert( sizeof( ImageMemoryBarrier ) == sizeof( VkImageMemoryBarrier ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageViewCreateInfo\r
+ {\r
+ ImageViewCreateInfo( ImageViewCreateFlags flags_ = ImageViewCreateFlags(), Image image_ = Image(), ImageViewType viewType_ = ImageViewType::e1D, Format format_ = Format::eUndefined, ComponentMapping components_ = ComponentMapping(), ImageSubresourceRange subresourceRange_ = ImageSubresourceRange() )\r
+ : flags( flags_ )\r
+ , image( image_ )\r
+ , viewType( viewType_ )\r
+ , format( format_ )\r
+ , components( components_ )\r
+ , subresourceRange( subresourceRange_ )\r
+ {\r
+ }\r
+\r
+ ImageViewCreateInfo( VkImageViewCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageViewCreateInfo ) );\r
+ }\r
+\r
+ ImageViewCreateInfo& operator=( VkImageViewCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageViewCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ImageViewCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewCreateInfo& setFlags( ImageViewCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewCreateInfo& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewCreateInfo& setViewType( ImageViewType viewType_ )\r
+ {\r
+ viewType = viewType_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewCreateInfo& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewCreateInfo& setComponents( ComponentMapping components_ )\r
+ {\r
+ components = components_;\r
+ return *this;\r
+ }\r
+\r
+ ImageViewCreateInfo& setSubresourceRange( ImageSubresourceRange subresourceRange_ )\r
+ {\r
+ subresourceRange = subresourceRange_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageViewCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageViewCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ImageViewCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( image == rhs.image )\r
+ && ( viewType == rhs.viewType )\r
+ && ( format == rhs.format )\r
+ && ( components == rhs.components )\r
+ && ( subresourceRange == rhs.subresourceRange );\r
+ }\r
+\r
+ bool operator!=( ImageViewCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageViewCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ImageViewCreateFlags flags;\r
+ Image image;\r
+ ImageViewType viewType;\r
+ Format format;\r
+ ComponentMapping components;\r
+ ImageSubresourceRange subresourceRange;\r
+ };\r
+ static_assert( sizeof( ImageViewCreateInfo ) == sizeof( VkImageViewCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageCopy\r
+ {\r
+ ImageCopy( ImageSubresourceLayers srcSubresource_ = ImageSubresourceLayers(), Offset3D srcOffset_ = Offset3D(), ImageSubresourceLayers dstSubresource_ = ImageSubresourceLayers(), Offset3D dstOffset_ = Offset3D(), Extent3D extent_ = Extent3D() )\r
+ : srcSubresource( srcSubresource_ )\r
+ , srcOffset( srcOffset_ )\r
+ , dstSubresource( dstSubresource_ )\r
+ , dstOffset( dstOffset_ )\r
+ , extent( extent_ )\r
+ {\r
+ }\r
+\r
+ ImageCopy( VkImageCopy const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageCopy ) );\r
+ }\r
+\r
+ ImageCopy& operator=( VkImageCopy const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageCopy ) );\r
+ return *this;\r
+ }\r
+ ImageCopy& setSrcSubresource( ImageSubresourceLayers srcSubresource_ )\r
+ {\r
+ srcSubresource = srcSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCopy& setSrcOffset( Offset3D srcOffset_ )\r
+ {\r
+ srcOffset = srcOffset_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCopy& setDstSubresource( ImageSubresourceLayers dstSubresource_ )\r
+ {\r
+ dstSubresource = dstSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCopy& setDstOffset( Offset3D dstOffset_ )\r
+ {\r
+ dstOffset = dstOffset_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCopy& setExtent( Extent3D extent_ )\r
+ {\r
+ extent = extent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageCopy&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageCopy*>(this);\r
+ }\r
+\r
+ bool operator==( ImageCopy const& rhs ) const\r
+ {\r
+ return ( srcSubresource == rhs.srcSubresource )\r
+ && ( srcOffset == rhs.srcOffset )\r
+ && ( dstSubresource == rhs.dstSubresource )\r
+ && ( dstOffset == rhs.dstOffset )\r
+ && ( extent == rhs.extent );\r
+ }\r
+\r
+ bool operator!=( ImageCopy const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageSubresourceLayers srcSubresource;\r
+ Offset3D srcOffset;\r
+ ImageSubresourceLayers dstSubresource;\r
+ Offset3D dstOffset;\r
+ Extent3D extent;\r
+ };\r
+ static_assert( sizeof( ImageCopy ) == sizeof( VkImageCopy ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageBlit\r
+ {\r
+ ImageBlit( ImageSubresourceLayers srcSubresource_ = ImageSubresourceLayers(), std::array<Offset3D,2> const& srcOffsets_ = { { Offset3D(), Offset3D() } }, ImageSubresourceLayers dstSubresource_ = ImageSubresourceLayers(), std::array<Offset3D,2> const& dstOffsets_ = { { Offset3D(), Offset3D() } } )\r
+ : srcSubresource( srcSubresource_ )\r
+ , dstSubresource( dstSubresource_ )\r
+ {\r
+ memcpy( &srcOffsets, srcOffsets_.data(), 2 * sizeof( Offset3D ) );\r
+ memcpy( &dstOffsets, dstOffsets_.data(), 2 * sizeof( Offset3D ) );\r
+ }\r
+\r
+ ImageBlit( VkImageBlit const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageBlit ) );\r
+ }\r
+\r
+ ImageBlit& operator=( VkImageBlit const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageBlit ) );\r
+ return *this;\r
+ }\r
+ ImageBlit& setSrcSubresource( ImageSubresourceLayers srcSubresource_ )\r
+ {\r
+ srcSubresource = srcSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ ImageBlit& setSrcOffsets( std::array<Offset3D,2> srcOffsets_ )\r
+ {\r
+ memcpy( &srcOffsets, srcOffsets_.data(), 2 * sizeof( Offset3D ) );\r
+ return *this;\r
+ }\r
+\r
+ ImageBlit& setDstSubresource( ImageSubresourceLayers dstSubresource_ )\r
+ {\r
+ dstSubresource = dstSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ ImageBlit& setDstOffsets( std::array<Offset3D,2> dstOffsets_ )\r
+ {\r
+ memcpy( &dstOffsets, dstOffsets_.data(), 2 * sizeof( Offset3D ) );\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageBlit&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageBlit*>(this);\r
+ }\r
+\r
+ bool operator==( ImageBlit const& rhs ) const\r
+ {\r
+ return ( srcSubresource == rhs.srcSubresource )\r
+ && ( memcmp( srcOffsets, rhs.srcOffsets, 2 * sizeof( Offset3D ) ) == 0 )\r
+ && ( dstSubresource == rhs.dstSubresource )\r
+ && ( memcmp( dstOffsets, rhs.dstOffsets, 2 * sizeof( Offset3D ) ) == 0 );\r
+ }\r
+\r
+ bool operator!=( ImageBlit const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageSubresourceLayers srcSubresource;\r
+ Offset3D srcOffsets[2];\r
+ ImageSubresourceLayers dstSubresource;\r
+ Offset3D dstOffsets[2];\r
+ };\r
+ static_assert( sizeof( ImageBlit ) == sizeof( VkImageBlit ), "struct and wrapper have different size!" );\r
+\r
+ struct BufferImageCopy\r
+ {\r
+ BufferImageCopy( DeviceSize bufferOffset_ = 0, uint32_t bufferRowLength_ = 0, uint32_t bufferImageHeight_ = 0, ImageSubresourceLayers imageSubresource_ = ImageSubresourceLayers(), Offset3D imageOffset_ = Offset3D(), Extent3D imageExtent_ = Extent3D() )\r
+ : bufferOffset( bufferOffset_ )\r
+ , bufferRowLength( bufferRowLength_ )\r
+ , bufferImageHeight( bufferImageHeight_ )\r
+ , imageSubresource( imageSubresource_ )\r
+ , imageOffset( imageOffset_ )\r
+ , imageExtent( imageExtent_ )\r
+ {\r
+ }\r
+\r
+ BufferImageCopy( VkBufferImageCopy const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferImageCopy ) );\r
+ }\r
+\r
+ BufferImageCopy& operator=( VkBufferImageCopy const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BufferImageCopy ) );\r
+ return *this;\r
+ }\r
+ BufferImageCopy& setBufferOffset( DeviceSize bufferOffset_ )\r
+ {\r
+ bufferOffset = bufferOffset_;\r
+ return *this;\r
+ }\r
+\r
+ BufferImageCopy& setBufferRowLength( uint32_t bufferRowLength_ )\r
+ {\r
+ bufferRowLength = bufferRowLength_;\r
+ return *this;\r
+ }\r
+\r
+ BufferImageCopy& setBufferImageHeight( uint32_t bufferImageHeight_ )\r
+ {\r
+ bufferImageHeight = bufferImageHeight_;\r
+ return *this;\r
+ }\r
+\r
+ BufferImageCopy& setImageSubresource( ImageSubresourceLayers imageSubresource_ )\r
+ {\r
+ imageSubresource = imageSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ BufferImageCopy& setImageOffset( Offset3D imageOffset_ )\r
+ {\r
+ imageOffset = imageOffset_;\r
+ return *this;\r
+ }\r
+\r
+ BufferImageCopy& setImageExtent( Extent3D imageExtent_ )\r
+ {\r
+ imageExtent = imageExtent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBufferImageCopy&() const\r
+ {\r
+ return *reinterpret_cast<const VkBufferImageCopy*>(this);\r
+ }\r
+\r
+ bool operator==( BufferImageCopy const& rhs ) const\r
+ {\r
+ return ( bufferOffset == rhs.bufferOffset )\r
+ && ( bufferRowLength == rhs.bufferRowLength )\r
+ && ( bufferImageHeight == rhs.bufferImageHeight )\r
+ && ( imageSubresource == rhs.imageSubresource )\r
+ && ( imageOffset == rhs.imageOffset )\r
+ && ( imageExtent == rhs.imageExtent );\r
+ }\r
+\r
+ bool operator!=( BufferImageCopy const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DeviceSize bufferOffset;\r
+ uint32_t bufferRowLength;\r
+ uint32_t bufferImageHeight;\r
+ ImageSubresourceLayers imageSubresource;\r
+ Offset3D imageOffset;\r
+ Extent3D imageExtent;\r
+ };\r
+ static_assert( sizeof( BufferImageCopy ) == sizeof( VkBufferImageCopy ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageResolve\r
+ {\r
+ ImageResolve( ImageSubresourceLayers srcSubresource_ = ImageSubresourceLayers(), Offset3D srcOffset_ = Offset3D(), ImageSubresourceLayers dstSubresource_ = ImageSubresourceLayers(), Offset3D dstOffset_ = Offset3D(), Extent3D extent_ = Extent3D() )\r
+ : srcSubresource( srcSubresource_ )\r
+ , srcOffset( srcOffset_ )\r
+ , dstSubresource( dstSubresource_ )\r
+ , dstOffset( dstOffset_ )\r
+ , extent( extent_ )\r
+ {\r
+ }\r
+\r
+ ImageResolve( VkImageResolve const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageResolve ) );\r
+ }\r
+\r
+ ImageResolve& operator=( VkImageResolve const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageResolve ) );\r
+ return *this;\r
+ }\r
+ ImageResolve& setSrcSubresource( ImageSubresourceLayers srcSubresource_ )\r
+ {\r
+ srcSubresource = srcSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ ImageResolve& setSrcOffset( Offset3D srcOffset_ )\r
+ {\r
+ srcOffset = srcOffset_;\r
+ return *this;\r
+ }\r
+\r
+ ImageResolve& setDstSubresource( ImageSubresourceLayers dstSubresource_ )\r
+ {\r
+ dstSubresource = dstSubresource_;\r
+ return *this;\r
+ }\r
+\r
+ ImageResolve& setDstOffset( Offset3D dstOffset_ )\r
+ {\r
+ dstOffset = dstOffset_;\r
+ return *this;\r
+ }\r
+\r
+ ImageResolve& setExtent( Extent3D extent_ )\r
+ {\r
+ extent = extent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageResolve&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageResolve*>(this);\r
+ }\r
+\r
+ bool operator==( ImageResolve const& rhs ) const\r
+ {\r
+ return ( srcSubresource == rhs.srcSubresource )\r
+ && ( srcOffset == rhs.srcOffset )\r
+ && ( dstSubresource == rhs.dstSubresource )\r
+ && ( dstOffset == rhs.dstOffset )\r
+ && ( extent == rhs.extent );\r
+ }\r
+\r
+ bool operator!=( ImageResolve const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageSubresourceLayers srcSubresource;\r
+ Offset3D srcOffset;\r
+ ImageSubresourceLayers dstSubresource;\r
+ Offset3D dstOffset;\r
+ Extent3D extent;\r
+ };\r
+ static_assert( sizeof( ImageResolve ) == sizeof( VkImageResolve ), "struct and wrapper have different size!" );\r
+\r
+ struct ClearAttachment\r
+ {\r
+ ClearAttachment( ImageAspectFlags aspectMask_ = ImageAspectFlags(), uint32_t colorAttachment_ = 0, ClearValue clearValue_ = ClearValue() )\r
+ : aspectMask( aspectMask_ )\r
+ , colorAttachment( colorAttachment_ )\r
+ , clearValue( clearValue_ )\r
+ {\r
+ }\r
+\r
+ ClearAttachment( VkClearAttachment const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ClearAttachment ) );\r
+ }\r
+\r
+ ClearAttachment& operator=( VkClearAttachment const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ClearAttachment ) );\r
+ return *this;\r
+ }\r
+ ClearAttachment& setAspectMask( ImageAspectFlags aspectMask_ )\r
+ {\r
+ aspectMask = aspectMask_;\r
+ return *this;\r
+ }\r
+\r
+ ClearAttachment& setColorAttachment( uint32_t colorAttachment_ )\r
+ {\r
+ colorAttachment = colorAttachment_;\r
+ return *this;\r
+ }\r
+\r
+ ClearAttachment& setClearValue( ClearValue clearValue_ )\r
+ {\r
+ clearValue = clearValue_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkClearAttachment&() const\r
+ {\r
+ return *reinterpret_cast<const VkClearAttachment*>(this);\r
+ }\r
+\r
+ ImageAspectFlags aspectMask;\r
+ uint32_t colorAttachment;\r
+ ClearValue clearValue;\r
+ };\r
+ static_assert( sizeof( ClearAttachment ) == sizeof( VkClearAttachment ), "struct and wrapper have different size!" );\r
+\r
+ struct InputAttachmentAspectReference\r
+ {\r
+ InputAttachmentAspectReference( uint32_t subpass_ = 0, uint32_t inputAttachmentIndex_ = 0, ImageAspectFlags aspectMask_ = ImageAspectFlags() )\r
+ : subpass( subpass_ )\r
+ , inputAttachmentIndex( inputAttachmentIndex_ )\r
+ , aspectMask( aspectMask_ )\r
+ {\r
+ }\r
+\r
+ InputAttachmentAspectReference( VkInputAttachmentAspectReference const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( InputAttachmentAspectReference ) );\r
+ }\r
+\r
+ InputAttachmentAspectReference& operator=( VkInputAttachmentAspectReference const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( InputAttachmentAspectReference ) );\r
+ return *this;\r
+ }\r
+ InputAttachmentAspectReference& setSubpass( uint32_t subpass_ )\r
+ {\r
+ subpass = subpass_;\r
+ return *this;\r
+ }\r
+\r
+ InputAttachmentAspectReference& setInputAttachmentIndex( uint32_t inputAttachmentIndex_ )\r
+ {\r
+ inputAttachmentIndex = inputAttachmentIndex_;\r
+ return *this;\r
+ }\r
+\r
+ InputAttachmentAspectReference& setAspectMask( ImageAspectFlags aspectMask_ )\r
+ {\r
+ aspectMask = aspectMask_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkInputAttachmentAspectReference&() const\r
+ {\r
+ return *reinterpret_cast<const VkInputAttachmentAspectReference*>(this);\r
+ }\r
+\r
+ bool operator==( InputAttachmentAspectReference const& rhs ) const\r
+ {\r
+ return ( subpass == rhs.subpass )\r
+ && ( inputAttachmentIndex == rhs.inputAttachmentIndex )\r
+ && ( aspectMask == rhs.aspectMask );\r
+ }\r
+\r
+ bool operator!=( InputAttachmentAspectReference const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t subpass;\r
+ uint32_t inputAttachmentIndex;\r
+ ImageAspectFlags aspectMask;\r
+ };\r
+ static_assert( sizeof( InputAttachmentAspectReference ) == sizeof( VkInputAttachmentAspectReference ), "struct and wrapper have different size!" );\r
+\r
+ using InputAttachmentAspectReferenceKHR = InputAttachmentAspectReference;\r
+\r
+ struct RenderPassInputAttachmentAspectCreateInfo\r
+ {\r
+ RenderPassInputAttachmentAspectCreateInfo( uint32_t aspectReferenceCount_ = 0, const InputAttachmentAspectReference* pAspectReferences_ = nullptr )\r
+ : aspectReferenceCount( aspectReferenceCount_ )\r
+ , pAspectReferences( pAspectReferences_ )\r
+ {\r
+ }\r
+\r
+ RenderPassInputAttachmentAspectCreateInfo( VkRenderPassInputAttachmentAspectCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassInputAttachmentAspectCreateInfo ) );\r
+ }\r
+\r
+ RenderPassInputAttachmentAspectCreateInfo& operator=( VkRenderPassInputAttachmentAspectCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassInputAttachmentAspectCreateInfo ) );\r
+ return *this;\r
+ }\r
+ RenderPassInputAttachmentAspectCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassInputAttachmentAspectCreateInfo& setAspectReferenceCount( uint32_t aspectReferenceCount_ )\r
+ {\r
+ aspectReferenceCount = aspectReferenceCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassInputAttachmentAspectCreateInfo& setPAspectReferences( const InputAttachmentAspectReference* pAspectReferences_ )\r
+ {\r
+ pAspectReferences = pAspectReferences_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRenderPassInputAttachmentAspectCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkRenderPassInputAttachmentAspectCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( RenderPassInputAttachmentAspectCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( aspectReferenceCount == rhs.aspectReferenceCount )\r
+ && ( pAspectReferences == rhs.pAspectReferences );\r
+ }\r
+\r
+ bool operator!=( RenderPassInputAttachmentAspectCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eRenderPassInputAttachmentAspectCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t aspectReferenceCount;\r
+ const InputAttachmentAspectReference* pAspectReferences;\r
+ };\r
+ static_assert( sizeof( RenderPassInputAttachmentAspectCreateInfo ) == sizeof( VkRenderPassInputAttachmentAspectCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using RenderPassInputAttachmentAspectCreateInfoKHR = RenderPassInputAttachmentAspectCreateInfo;\r
+\r
+ struct BindImagePlaneMemoryInfo\r
+ {\r
+ BindImagePlaneMemoryInfo( ImageAspectFlagBits planeAspect_ = ImageAspectFlagBits::eColor )\r
+ : planeAspect( planeAspect_ )\r
+ {\r
+ }\r
+\r
+ BindImagePlaneMemoryInfo( VkBindImagePlaneMemoryInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImagePlaneMemoryInfo ) );\r
+ }\r
+\r
+ BindImagePlaneMemoryInfo& operator=( VkBindImagePlaneMemoryInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindImagePlaneMemoryInfo ) );\r
+ return *this;\r
+ }\r
+ BindImagePlaneMemoryInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindImagePlaneMemoryInfo& setPlaneAspect( ImageAspectFlagBits planeAspect_ )\r
+ {\r
+ planeAspect = planeAspect_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindImagePlaneMemoryInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindImagePlaneMemoryInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BindImagePlaneMemoryInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( planeAspect == rhs.planeAspect );\r
+ }\r
+\r
+ bool operator!=( BindImagePlaneMemoryInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindImagePlaneMemoryInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ImageAspectFlagBits planeAspect;\r
+ };\r
+ static_assert( sizeof( BindImagePlaneMemoryInfo ) == sizeof( VkBindImagePlaneMemoryInfo ), "struct and wrapper have different size!" );\r
+\r
+ using BindImagePlaneMemoryInfoKHR = BindImagePlaneMemoryInfo;\r
+\r
+ struct ImagePlaneMemoryRequirementsInfo\r
+ {\r
+ ImagePlaneMemoryRequirementsInfo( ImageAspectFlagBits planeAspect_ = ImageAspectFlagBits::eColor )\r
+ : planeAspect( planeAspect_ )\r
+ {\r
+ }\r
+\r
+ ImagePlaneMemoryRequirementsInfo( VkImagePlaneMemoryRequirementsInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImagePlaneMemoryRequirementsInfo ) );\r
+ }\r
+\r
+ ImagePlaneMemoryRequirementsInfo& operator=( VkImagePlaneMemoryRequirementsInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImagePlaneMemoryRequirementsInfo ) );\r
+ return *this;\r
+ }\r
+ ImagePlaneMemoryRequirementsInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImagePlaneMemoryRequirementsInfo& setPlaneAspect( ImageAspectFlagBits planeAspect_ )\r
+ {\r
+ planeAspect = planeAspect_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImagePlaneMemoryRequirementsInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkImagePlaneMemoryRequirementsInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ImagePlaneMemoryRequirementsInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( planeAspect == rhs.planeAspect );\r
+ }\r
+\r
+ bool operator!=( ImagePlaneMemoryRequirementsInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImagePlaneMemoryRequirementsInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ImageAspectFlagBits planeAspect;\r
+ };\r
+ static_assert( sizeof( ImagePlaneMemoryRequirementsInfo ) == sizeof( VkImagePlaneMemoryRequirementsInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ImagePlaneMemoryRequirementsInfoKHR = ImagePlaneMemoryRequirementsInfo;\r
+\r
+ enum class SparseImageFormatFlagBits\r
+ {\r
+ eSingleMiptail = VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT,\r
+ eAlignedMipSize = VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT,\r
+ eNonstandardBlockSize = VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT\r
+ };\r
+\r
+ using SparseImageFormatFlags = Flags<SparseImageFormatFlagBits, VkSparseImageFormatFlags>;\r
+\r
+ VULKAN_HPP_INLINE SparseImageFormatFlags operator|( SparseImageFormatFlagBits bit0, SparseImageFormatFlagBits bit1 )\r
+ {\r
+ return SparseImageFormatFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SparseImageFormatFlags operator~( SparseImageFormatFlagBits bits )\r
+ {\r
+ return ~( SparseImageFormatFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SparseImageFormatFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SparseImageFormatFlagBits::eSingleMiptail) | VkFlags(SparseImageFormatFlagBits::eAlignedMipSize) | VkFlags(SparseImageFormatFlagBits::eNonstandardBlockSize)\r
+ };\r
+ };\r
+\r
+ struct SparseImageFormatProperties\r
+ {\r
+ operator const VkSparseImageFormatProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageFormatProperties*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageFormatProperties const& rhs ) const\r
+ {\r
+ return ( aspectMask == rhs.aspectMask )\r
+ && ( imageGranularity == rhs.imageGranularity )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( SparseImageFormatProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageAspectFlags aspectMask;\r
+ Extent3D imageGranularity;\r
+ SparseImageFormatFlags flags;\r
+ };\r
+ static_assert( sizeof( SparseImageFormatProperties ) == sizeof( VkSparseImageFormatProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct SparseImageMemoryRequirements\r
+ {\r
+ operator const VkSparseImageMemoryRequirements&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageMemoryRequirements*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageMemoryRequirements const& rhs ) const\r
+ {\r
+ return ( formatProperties == rhs.formatProperties )\r
+ && ( imageMipTailFirstLod == rhs.imageMipTailFirstLod )\r
+ && ( imageMipTailSize == rhs.imageMipTailSize )\r
+ && ( imageMipTailOffset == rhs.imageMipTailOffset )\r
+ && ( imageMipTailStride == rhs.imageMipTailStride );\r
+ }\r
+\r
+ bool operator!=( SparseImageMemoryRequirements const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ SparseImageFormatProperties formatProperties;\r
+ uint32_t imageMipTailFirstLod;\r
+ DeviceSize imageMipTailSize;\r
+ DeviceSize imageMipTailOffset;\r
+ DeviceSize imageMipTailStride;\r
+ };\r
+ static_assert( sizeof( SparseImageMemoryRequirements ) == sizeof( VkSparseImageMemoryRequirements ), "struct and wrapper have different size!" );\r
+\r
+ struct SparseImageFormatProperties2\r
+ {\r
+ operator const VkSparseImageFormatProperties2&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageFormatProperties2*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageFormatProperties2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( properties == rhs.properties );\r
+ }\r
+\r
+ bool operator!=( SparseImageFormatProperties2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSparseImageFormatProperties2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ SparseImageFormatProperties properties;\r
+ };\r
+ static_assert( sizeof( SparseImageFormatProperties2 ) == sizeof( VkSparseImageFormatProperties2 ), "struct and wrapper have different size!" );\r
+\r
+ using SparseImageFormatProperties2KHR = SparseImageFormatProperties2;\r
+\r
+ struct SparseImageMemoryRequirements2\r
+ {\r
+ operator const VkSparseImageMemoryRequirements2&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageMemoryRequirements2*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageMemoryRequirements2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memoryRequirements == rhs.memoryRequirements );\r
+ }\r
+\r
+ bool operator!=( SparseImageMemoryRequirements2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSparseImageMemoryRequirements2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ SparseImageMemoryRequirements memoryRequirements;\r
+ };\r
+ static_assert( sizeof( SparseImageMemoryRequirements2 ) == sizeof( VkSparseImageMemoryRequirements2 ), "struct and wrapper have different size!" );\r
+\r
+ using SparseImageMemoryRequirements2KHR = SparseImageMemoryRequirements2;\r
+\r
+ enum class SparseMemoryBindFlagBits\r
+ {\r
+ eMetadata = VK_SPARSE_MEMORY_BIND_METADATA_BIT\r
+ };\r
+\r
+ using SparseMemoryBindFlags = Flags<SparseMemoryBindFlagBits, VkSparseMemoryBindFlags>;\r
+\r
+ VULKAN_HPP_INLINE SparseMemoryBindFlags operator|( SparseMemoryBindFlagBits bit0, SparseMemoryBindFlagBits bit1 )\r
+ {\r
+ return SparseMemoryBindFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SparseMemoryBindFlags operator~( SparseMemoryBindFlagBits bits )\r
+ {\r
+ return ~( SparseMemoryBindFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SparseMemoryBindFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SparseMemoryBindFlagBits::eMetadata)\r
+ };\r
+ };\r
+\r
+ struct SparseMemoryBind\r
+ {\r
+ SparseMemoryBind( DeviceSize resourceOffset_ = 0, DeviceSize size_ = 0, DeviceMemory memory_ = DeviceMemory(), DeviceSize memoryOffset_ = 0, SparseMemoryBindFlags flags_ = SparseMemoryBindFlags() )\r
+ : resourceOffset( resourceOffset_ )\r
+ , size( size_ )\r
+ , memory( memory_ )\r
+ , memoryOffset( memoryOffset_ )\r
+ , flags( flags_ )\r
+ {\r
+ }\r
+\r
+ SparseMemoryBind( VkSparseMemoryBind const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseMemoryBind ) );\r
+ }\r
+\r
+ SparseMemoryBind& operator=( VkSparseMemoryBind const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseMemoryBind ) );\r
+ return *this;\r
+ }\r
+ SparseMemoryBind& setResourceOffset( DeviceSize resourceOffset_ )\r
+ {\r
+ resourceOffset = resourceOffset_;\r
+ return *this;\r
+ }\r
+\r
+ SparseMemoryBind& setSize( DeviceSize size_ )\r
+ {\r
+ size = size_;\r
+ return *this;\r
+ }\r
+\r
+ SparseMemoryBind& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ SparseMemoryBind& setMemoryOffset( DeviceSize memoryOffset_ )\r
+ {\r
+ memoryOffset = memoryOffset_;\r
+ return *this;\r
+ }\r
+\r
+ SparseMemoryBind& setFlags( SparseMemoryBindFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSparseMemoryBind&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseMemoryBind*>(this);\r
+ }\r
+\r
+ bool operator==( SparseMemoryBind const& rhs ) const\r
+ {\r
+ return ( resourceOffset == rhs.resourceOffset )\r
+ && ( size == rhs.size )\r
+ && ( memory == rhs.memory )\r
+ && ( memoryOffset == rhs.memoryOffset )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( SparseMemoryBind const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DeviceSize resourceOffset;\r
+ DeviceSize size;\r
+ DeviceMemory memory;\r
+ DeviceSize memoryOffset;\r
+ SparseMemoryBindFlags flags;\r
+ };\r
+ static_assert( sizeof( SparseMemoryBind ) == sizeof( VkSparseMemoryBind ), "struct and wrapper have different size!" );\r
+\r
+ struct SparseImageMemoryBind\r
+ {\r
+ SparseImageMemoryBind( ImageSubresource subresource_ = ImageSubresource(), Offset3D offset_ = Offset3D(), Extent3D extent_ = Extent3D(), DeviceMemory memory_ = DeviceMemory(), DeviceSize memoryOffset_ = 0, SparseMemoryBindFlags flags_ = SparseMemoryBindFlags() )\r
+ : subresource( subresource_ )\r
+ , offset( offset_ )\r
+ , extent( extent_ )\r
+ , memory( memory_ )\r
+ , memoryOffset( memoryOffset_ )\r
+ , flags( flags_ )\r
+ {\r
+ }\r
+\r
+ SparseImageMemoryBind( VkSparseImageMemoryBind const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseImageMemoryBind ) );\r
+ }\r
+\r
+ SparseImageMemoryBind& operator=( VkSparseImageMemoryBind const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseImageMemoryBind ) );\r
+ return *this;\r
+ }\r
+ SparseImageMemoryBind& setSubresource( ImageSubresource subresource_ )\r
+ {\r
+ subresource = subresource_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBind& setOffset( Offset3D offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBind& setExtent( Extent3D extent_ )\r
+ {\r
+ extent = extent_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBind& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBind& setMemoryOffset( DeviceSize memoryOffset_ )\r
+ {\r
+ memoryOffset = memoryOffset_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBind& setFlags( SparseMemoryBindFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSparseImageMemoryBind&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageMemoryBind*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageMemoryBind const& rhs ) const\r
+ {\r
+ return ( subresource == rhs.subresource )\r
+ && ( offset == rhs.offset )\r
+ && ( extent == rhs.extent )\r
+ && ( memory == rhs.memory )\r
+ && ( memoryOffset == rhs.memoryOffset )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( SparseImageMemoryBind const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageSubresource subresource;\r
+ Offset3D offset;\r
+ Extent3D extent;\r
+ DeviceMemory memory;\r
+ DeviceSize memoryOffset;\r
+ SparseMemoryBindFlags flags;\r
+ };\r
+ static_assert( sizeof( SparseImageMemoryBind ) == sizeof( VkSparseImageMemoryBind ), "struct and wrapper have different size!" );\r
+\r
+ struct SparseBufferMemoryBindInfo\r
+ {\r
+ SparseBufferMemoryBindInfo( Buffer buffer_ = Buffer(), uint32_t bindCount_ = 0, const SparseMemoryBind* pBinds_ = nullptr )\r
+ : buffer( buffer_ )\r
+ , bindCount( bindCount_ )\r
+ , pBinds( pBinds_ )\r
+ {\r
+ }\r
+\r
+ SparseBufferMemoryBindInfo( VkSparseBufferMemoryBindInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseBufferMemoryBindInfo ) );\r
+ }\r
+\r
+ SparseBufferMemoryBindInfo& operator=( VkSparseBufferMemoryBindInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseBufferMemoryBindInfo ) );\r
+ return *this;\r
+ }\r
+ SparseBufferMemoryBindInfo& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ SparseBufferMemoryBindInfo& setBindCount( uint32_t bindCount_ )\r
+ {\r
+ bindCount = bindCount_;\r
+ return *this;\r
+ }\r
+\r
+ SparseBufferMemoryBindInfo& setPBinds( const SparseMemoryBind* pBinds_ )\r
+ {\r
+ pBinds = pBinds_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSparseBufferMemoryBindInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseBufferMemoryBindInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SparseBufferMemoryBindInfo const& rhs ) const\r
+ {\r
+ return ( buffer == rhs.buffer )\r
+ && ( bindCount == rhs.bindCount )\r
+ && ( pBinds == rhs.pBinds );\r
+ }\r
+\r
+ bool operator!=( SparseBufferMemoryBindInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Buffer buffer;\r
+ uint32_t bindCount;\r
+ const SparseMemoryBind* pBinds;\r
+ };\r
+ static_assert( sizeof( SparseBufferMemoryBindInfo ) == sizeof( VkSparseBufferMemoryBindInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct SparseImageOpaqueMemoryBindInfo\r
+ {\r
+ SparseImageOpaqueMemoryBindInfo( Image image_ = Image(), uint32_t bindCount_ = 0, const SparseMemoryBind* pBinds_ = nullptr )\r
+ : image( image_ )\r
+ , bindCount( bindCount_ )\r
+ , pBinds( pBinds_ )\r
+ {\r
+ }\r
+\r
+ SparseImageOpaqueMemoryBindInfo( VkSparseImageOpaqueMemoryBindInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseImageOpaqueMemoryBindInfo ) );\r
+ }\r
+\r
+ SparseImageOpaqueMemoryBindInfo& operator=( VkSparseImageOpaqueMemoryBindInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseImageOpaqueMemoryBindInfo ) );\r
+ return *this;\r
+ }\r
+ SparseImageOpaqueMemoryBindInfo& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageOpaqueMemoryBindInfo& setBindCount( uint32_t bindCount_ )\r
+ {\r
+ bindCount = bindCount_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageOpaqueMemoryBindInfo& setPBinds( const SparseMemoryBind* pBinds_ )\r
+ {\r
+ pBinds = pBinds_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSparseImageOpaqueMemoryBindInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageOpaqueMemoryBindInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageOpaqueMemoryBindInfo const& rhs ) const\r
+ {\r
+ return ( image == rhs.image )\r
+ && ( bindCount == rhs.bindCount )\r
+ && ( pBinds == rhs.pBinds );\r
+ }\r
+\r
+ bool operator!=( SparseImageOpaqueMemoryBindInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Image image;\r
+ uint32_t bindCount;\r
+ const SparseMemoryBind* pBinds;\r
+ };\r
+ static_assert( sizeof( SparseImageOpaqueMemoryBindInfo ) == sizeof( VkSparseImageOpaqueMemoryBindInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct SparseImageMemoryBindInfo\r
+ {\r
+ SparseImageMemoryBindInfo( Image image_ = Image(), uint32_t bindCount_ = 0, const SparseImageMemoryBind* pBinds_ = nullptr )\r
+ : image( image_ )\r
+ , bindCount( bindCount_ )\r
+ , pBinds( pBinds_ )\r
+ {\r
+ }\r
+\r
+ SparseImageMemoryBindInfo( VkSparseImageMemoryBindInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseImageMemoryBindInfo ) );\r
+ }\r
+\r
+ SparseImageMemoryBindInfo& operator=( VkSparseImageMemoryBindInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SparseImageMemoryBindInfo ) );\r
+ return *this;\r
+ }\r
+ SparseImageMemoryBindInfo& setImage( Image image_ )\r
+ {\r
+ image = image_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBindInfo& setBindCount( uint32_t bindCount_ )\r
+ {\r
+ bindCount = bindCount_;\r
+ return *this;\r
+ }\r
+\r
+ SparseImageMemoryBindInfo& setPBinds( const SparseImageMemoryBind* pBinds_ )\r
+ {\r
+ pBinds = pBinds_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSparseImageMemoryBindInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSparseImageMemoryBindInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SparseImageMemoryBindInfo const& rhs ) const\r
+ {\r
+ return ( image == rhs.image )\r
+ && ( bindCount == rhs.bindCount )\r
+ && ( pBinds == rhs.pBinds );\r
+ }\r
+\r
+ bool operator!=( SparseImageMemoryBindInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Image image;\r
+ uint32_t bindCount;\r
+ const SparseImageMemoryBind* pBinds;\r
+ };\r
+ static_assert( sizeof( SparseImageMemoryBindInfo ) == sizeof( VkSparseImageMemoryBindInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct BindSparseInfo\r
+ {\r
+ BindSparseInfo( uint32_t waitSemaphoreCount_ = 0, const Semaphore* pWaitSemaphores_ = nullptr, uint32_t bufferBindCount_ = 0, const SparseBufferMemoryBindInfo* pBufferBinds_ = nullptr, uint32_t imageOpaqueBindCount_ = 0, const SparseImageOpaqueMemoryBindInfo* pImageOpaqueBinds_ = nullptr, uint32_t imageBindCount_ = 0, const SparseImageMemoryBindInfo* pImageBinds_ = nullptr, uint32_t signalSemaphoreCount_ = 0, const Semaphore* pSignalSemaphores_ = nullptr )\r
+ : waitSemaphoreCount( waitSemaphoreCount_ )\r
+ , pWaitSemaphores( pWaitSemaphores_ )\r
+ , bufferBindCount( bufferBindCount_ )\r
+ , pBufferBinds( pBufferBinds_ )\r
+ , imageOpaqueBindCount( imageOpaqueBindCount_ )\r
+ , pImageOpaqueBinds( pImageOpaqueBinds_ )\r
+ , imageBindCount( imageBindCount_ )\r
+ , pImageBinds( pImageBinds_ )\r
+ , signalSemaphoreCount( signalSemaphoreCount_ )\r
+ , pSignalSemaphores( pSignalSemaphores_ )\r
+ {\r
+ }\r
+\r
+ BindSparseInfo( VkBindSparseInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindSparseInfo ) );\r
+ }\r
+\r
+ BindSparseInfo& operator=( VkBindSparseInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( BindSparseInfo ) );\r
+ return *this;\r
+ }\r
+ BindSparseInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setWaitSemaphoreCount( uint32_t waitSemaphoreCount_ )\r
+ {\r
+ waitSemaphoreCount = waitSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setPWaitSemaphores( const Semaphore* pWaitSemaphores_ )\r
+ {\r
+ pWaitSemaphores = pWaitSemaphores_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setBufferBindCount( uint32_t bufferBindCount_ )\r
+ {\r
+ bufferBindCount = bufferBindCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setPBufferBinds( const SparseBufferMemoryBindInfo* pBufferBinds_ )\r
+ {\r
+ pBufferBinds = pBufferBinds_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setImageOpaqueBindCount( uint32_t imageOpaqueBindCount_ )\r
+ {\r
+ imageOpaqueBindCount = imageOpaqueBindCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setPImageOpaqueBinds( const SparseImageOpaqueMemoryBindInfo* pImageOpaqueBinds_ )\r
+ {\r
+ pImageOpaqueBinds = pImageOpaqueBinds_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setImageBindCount( uint32_t imageBindCount_ )\r
+ {\r
+ imageBindCount = imageBindCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setPImageBinds( const SparseImageMemoryBindInfo* pImageBinds_ )\r
+ {\r
+ pImageBinds = pImageBinds_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setSignalSemaphoreCount( uint32_t signalSemaphoreCount_ )\r
+ {\r
+ signalSemaphoreCount = signalSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ BindSparseInfo& setPSignalSemaphores( const Semaphore* pSignalSemaphores_ )\r
+ {\r
+ pSignalSemaphores = pSignalSemaphores_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkBindSparseInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkBindSparseInfo*>(this);\r
+ }\r
+\r
+ bool operator==( BindSparseInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( waitSemaphoreCount == rhs.waitSemaphoreCount )\r
+ && ( pWaitSemaphores == rhs.pWaitSemaphores )\r
+ && ( bufferBindCount == rhs.bufferBindCount )\r
+ && ( pBufferBinds == rhs.pBufferBinds )\r
+ && ( imageOpaqueBindCount == rhs.imageOpaqueBindCount )\r
+ && ( pImageOpaqueBinds == rhs.pImageOpaqueBinds )\r
+ && ( imageBindCount == rhs.imageBindCount )\r
+ && ( pImageBinds == rhs.pImageBinds )\r
+ && ( signalSemaphoreCount == rhs.signalSemaphoreCount )\r
+ && ( pSignalSemaphores == rhs.pSignalSemaphores );\r
+ }\r
+\r
+ bool operator!=( BindSparseInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eBindSparseInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t waitSemaphoreCount;\r
+ const Semaphore* pWaitSemaphores;\r
+ uint32_t bufferBindCount;\r
+ const SparseBufferMemoryBindInfo* pBufferBinds;\r
+ uint32_t imageOpaqueBindCount;\r
+ const SparseImageOpaqueMemoryBindInfo* pImageOpaqueBinds;\r
+ uint32_t imageBindCount;\r
+ const SparseImageMemoryBindInfo* pImageBinds;\r
+ uint32_t signalSemaphoreCount;\r
+ const Semaphore* pSignalSemaphores;\r
+ };\r
+ static_assert( sizeof( BindSparseInfo ) == sizeof( VkBindSparseInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class PipelineStageFlagBits\r
+ {\r
+ eTopOfPipe = VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,\r
+ eDrawIndirect = VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT,\r
+ eVertexInput = VK_PIPELINE_STAGE_VERTEX_INPUT_BIT,\r
+ eVertexShader = VK_PIPELINE_STAGE_VERTEX_SHADER_BIT,\r
+ eTessellationControlShader = VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT,\r
+ eTessellationEvaluationShader = VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT,\r
+ eGeometryShader = VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT,\r
+ eFragmentShader = VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT,\r
+ eEarlyFragmentTests = VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT,\r
+ eLateFragmentTests = VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT,\r
+ eColorAttachmentOutput = VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,\r
+ eComputeShader = VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT,\r
+ eTransfer = VK_PIPELINE_STAGE_TRANSFER_BIT,\r
+ eBottomOfPipe = VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT,\r
+ eHost = VK_PIPELINE_STAGE_HOST_BIT,\r
+ eAllGraphics = VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,\r
+ eAllCommands = VK_PIPELINE_STAGE_ALL_COMMANDS_BIT,\r
+ eCommandProcessNVX = VK_PIPELINE_STAGE_COMMAND_PROCESS_BIT_NVX\r
+ };\r
+\r
+ using PipelineStageFlags = Flags<PipelineStageFlagBits, VkPipelineStageFlags>;\r
+\r
+ VULKAN_HPP_INLINE PipelineStageFlags operator|( PipelineStageFlagBits bit0, PipelineStageFlagBits bit1 )\r
+ {\r
+ return PipelineStageFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE PipelineStageFlags operator~( PipelineStageFlagBits bits )\r
+ {\r
+ return ~( PipelineStageFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<PipelineStageFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(PipelineStageFlagBits::eTopOfPipe) | VkFlags(PipelineStageFlagBits::eDrawIndirect) | VkFlags(PipelineStageFlagBits::eVertexInput) | VkFlags(PipelineStageFlagBits::eVertexShader) | VkFlags(PipelineStageFlagBits::eTessellationControlShader) | VkFlags(PipelineStageFlagBits::eTessellationEvaluationShader) | VkFlags(PipelineStageFlagBits::eGeometryShader) | VkFlags(PipelineStageFlagBits::eFragmentShader) | VkFlags(PipelineStageFlagBits::eEarlyFragmentTests) | VkFlags(PipelineStageFlagBits::eLateFragmentTests) | VkFlags(PipelineStageFlagBits::eColorAttachmentOutput) | VkFlags(PipelineStageFlagBits::eComputeShader) | VkFlags(PipelineStageFlagBits::eTransfer) | VkFlags(PipelineStageFlagBits::eBottomOfPipe) | VkFlags(PipelineStageFlagBits::eHost) | VkFlags(PipelineStageFlagBits::eAllGraphics) | VkFlags(PipelineStageFlagBits::eAllCommands) | VkFlags(PipelineStageFlagBits::eCommandProcessNVX)\r
+ };\r
+ };\r
+\r
+ enum class CommandPoolCreateFlagBits\r
+ {\r
+ eTransient = VK_COMMAND_POOL_CREATE_TRANSIENT_BIT,\r
+ eResetCommandBuffer = VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT,\r
+ eProtected = VK_COMMAND_POOL_CREATE_PROTECTED_BIT\r
+ };\r
+\r
+ using CommandPoolCreateFlags = Flags<CommandPoolCreateFlagBits, VkCommandPoolCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE CommandPoolCreateFlags operator|( CommandPoolCreateFlagBits bit0, CommandPoolCreateFlagBits bit1 )\r
+ {\r
+ return CommandPoolCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE CommandPoolCreateFlags operator~( CommandPoolCreateFlagBits bits )\r
+ {\r
+ return ~( CommandPoolCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<CommandPoolCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(CommandPoolCreateFlagBits::eTransient) | VkFlags(CommandPoolCreateFlagBits::eResetCommandBuffer) | VkFlags(CommandPoolCreateFlagBits::eProtected)\r
+ };\r
+ };\r
+\r
+ struct CommandPoolCreateInfo\r
+ {\r
+ CommandPoolCreateInfo( CommandPoolCreateFlags flags_ = CommandPoolCreateFlags(), uint32_t queueFamilyIndex_ = 0 )\r
+ : flags( flags_ )\r
+ , queueFamilyIndex( queueFamilyIndex_ )\r
+ {\r
+ }\r
+\r
+ CommandPoolCreateInfo( VkCommandPoolCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandPoolCreateInfo ) );\r
+ }\r
+\r
+ CommandPoolCreateInfo& operator=( VkCommandPoolCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CommandPoolCreateInfo ) );\r
+ return *this;\r
+ }\r
+ CommandPoolCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CommandPoolCreateInfo& setFlags( CommandPoolCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ CommandPoolCreateInfo& setQueueFamilyIndex( uint32_t queueFamilyIndex_ )\r
+ {\r
+ queueFamilyIndex = queueFamilyIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCommandPoolCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkCommandPoolCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( CommandPoolCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( queueFamilyIndex == rhs.queueFamilyIndex );\r
+ }\r
+\r
+ bool operator!=( CommandPoolCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCommandPoolCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ CommandPoolCreateFlags flags;\r
+ uint32_t queueFamilyIndex;\r
+ };\r
+ static_assert( sizeof( CommandPoolCreateInfo ) == sizeof( VkCommandPoolCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class CommandPoolResetFlagBits\r
+ {\r
+ eReleaseResources = VK_COMMAND_POOL_RESET_RELEASE_RESOURCES_BIT\r
+ };\r
+\r
+ using CommandPoolResetFlags = Flags<CommandPoolResetFlagBits, VkCommandPoolResetFlags>;\r
+\r
+ VULKAN_HPP_INLINE CommandPoolResetFlags operator|( CommandPoolResetFlagBits bit0, CommandPoolResetFlagBits bit1 )\r
+ {\r
+ return CommandPoolResetFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE CommandPoolResetFlags operator~( CommandPoolResetFlagBits bits )\r
+ {\r
+ return ~( CommandPoolResetFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<CommandPoolResetFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(CommandPoolResetFlagBits::eReleaseResources)\r
+ };\r
+ };\r
+\r
+ enum class CommandBufferResetFlagBits\r
+ {\r
+ eReleaseResources = VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT\r
+ };\r
+\r
+ using CommandBufferResetFlags = Flags<CommandBufferResetFlagBits, VkCommandBufferResetFlags>;\r
+\r
+ VULKAN_HPP_INLINE CommandBufferResetFlags operator|( CommandBufferResetFlagBits bit0, CommandBufferResetFlagBits bit1 )\r
+ {\r
+ return CommandBufferResetFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE CommandBufferResetFlags operator~( CommandBufferResetFlagBits bits )\r
+ {\r
+ return ~( CommandBufferResetFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<CommandBufferResetFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(CommandBufferResetFlagBits::eReleaseResources)\r
+ };\r
+ };\r
+\r
+ enum class SampleCountFlagBits\r
+ {\r
+ e1 = VK_SAMPLE_COUNT_1_BIT,\r
+ e2 = VK_SAMPLE_COUNT_2_BIT,\r
+ e4 = VK_SAMPLE_COUNT_4_BIT,\r
+ e8 = VK_SAMPLE_COUNT_8_BIT,\r
+ e16 = VK_SAMPLE_COUNT_16_BIT,\r
+ e32 = VK_SAMPLE_COUNT_32_BIT,\r
+ e64 = VK_SAMPLE_COUNT_64_BIT\r
+ };\r
+\r
+ using SampleCountFlags = Flags<SampleCountFlagBits, VkSampleCountFlags>;\r
+\r
+ VULKAN_HPP_INLINE SampleCountFlags operator|( SampleCountFlagBits bit0, SampleCountFlagBits bit1 )\r
+ {\r
+ return SampleCountFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SampleCountFlags operator~( SampleCountFlagBits bits )\r
+ {\r
+ return ~( SampleCountFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SampleCountFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SampleCountFlagBits::e1) | VkFlags(SampleCountFlagBits::e2) | VkFlags(SampleCountFlagBits::e4) | VkFlags(SampleCountFlagBits::e8) | VkFlags(SampleCountFlagBits::e16) | VkFlags(SampleCountFlagBits::e32) | VkFlags(SampleCountFlagBits::e64)\r
+ };\r
+ };\r
+\r
+ struct ImageFormatProperties\r
+ {\r
+ operator const VkImageFormatProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageFormatProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ImageFormatProperties const& rhs ) const\r
+ {\r
+ return ( maxExtent == rhs.maxExtent )\r
+ && ( maxMipLevels == rhs.maxMipLevels )\r
+ && ( maxArrayLayers == rhs.maxArrayLayers )\r
+ && ( sampleCounts == rhs.sampleCounts )\r
+ && ( maxResourceSize == rhs.maxResourceSize );\r
+ }\r
+\r
+ bool operator!=( ImageFormatProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Extent3D maxExtent;\r
+ uint32_t maxMipLevels;\r
+ uint32_t maxArrayLayers;\r
+ SampleCountFlags sampleCounts;\r
+ DeviceSize maxResourceSize;\r
+ };\r
+ static_assert( sizeof( ImageFormatProperties ) == sizeof( VkImageFormatProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct ImageCreateInfo\r
+ {\r
+ ImageCreateInfo( ImageCreateFlags flags_ = ImageCreateFlags(), ImageType imageType_ = ImageType::e1D, Format format_ = Format::eUndefined, Extent3D extent_ = Extent3D(), uint32_t mipLevels_ = 0, uint32_t arrayLayers_ = 0, SampleCountFlagBits samples_ = SampleCountFlagBits::e1, ImageTiling tiling_ = ImageTiling::eOptimal, ImageUsageFlags usage_ = ImageUsageFlags(), SharingMode sharingMode_ = SharingMode::eExclusive, uint32_t queueFamilyIndexCount_ = 0, const uint32_t* pQueueFamilyIndices_ = nullptr, ImageLayout initialLayout_ = ImageLayout::eUndefined )\r
+ : flags( flags_ )\r
+ , imageType( imageType_ )\r
+ , format( format_ )\r
+ , extent( extent_ )\r
+ , mipLevels( mipLevels_ )\r
+ , arrayLayers( arrayLayers_ )\r
+ , samples( samples_ )\r
+ , tiling( tiling_ )\r
+ , usage( usage_ )\r
+ , sharingMode( sharingMode_ )\r
+ , queueFamilyIndexCount( queueFamilyIndexCount_ )\r
+ , pQueueFamilyIndices( pQueueFamilyIndices_ )\r
+ , initialLayout( initialLayout_ )\r
+ {\r
+ }\r
+\r
+ ImageCreateInfo( VkImageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageCreateInfo ) );\r
+ }\r
+\r
+ ImageCreateInfo& operator=( VkImageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImageCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ImageCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setFlags( ImageCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setImageType( ImageType imageType_ )\r
+ {\r
+ imageType = imageType_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setExtent( Extent3D extent_ )\r
+ {\r
+ extent = extent_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setMipLevels( uint32_t mipLevels_ )\r
+ {\r
+ mipLevels = mipLevels_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setArrayLayers( uint32_t arrayLayers_ )\r
+ {\r
+ arrayLayers = arrayLayers_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setSamples( SampleCountFlagBits samples_ )\r
+ {\r
+ samples = samples_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setTiling( ImageTiling tiling_ )\r
+ {\r
+ tiling = tiling_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setUsage( ImageUsageFlags usage_ )\r
+ {\r
+ usage = usage_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setSharingMode( SharingMode sharingMode_ )\r
+ {\r
+ sharingMode = sharingMode_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setQueueFamilyIndexCount( uint32_t queueFamilyIndexCount_ )\r
+ {\r
+ queueFamilyIndexCount = queueFamilyIndexCount_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setPQueueFamilyIndices( const uint32_t* pQueueFamilyIndices_ )\r
+ {\r
+ pQueueFamilyIndices = pQueueFamilyIndices_;\r
+ return *this;\r
+ }\r
+\r
+ ImageCreateInfo& setInitialLayout( ImageLayout initialLayout_ )\r
+ {\r
+ initialLayout = initialLayout_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImageCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ImageCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( imageType == rhs.imageType )\r
+ && ( format == rhs.format )\r
+ && ( extent == rhs.extent )\r
+ && ( mipLevels == rhs.mipLevels )\r
+ && ( arrayLayers == rhs.arrayLayers )\r
+ && ( samples == rhs.samples )\r
+ && ( tiling == rhs.tiling )\r
+ && ( usage == rhs.usage )\r
+ && ( sharingMode == rhs.sharingMode )\r
+ && ( queueFamilyIndexCount == rhs.queueFamilyIndexCount )\r
+ && ( pQueueFamilyIndices == rhs.pQueueFamilyIndices )\r
+ && ( initialLayout == rhs.initialLayout );\r
+ }\r
+\r
+ bool operator!=( ImageCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ImageCreateFlags flags;\r
+ ImageType imageType;\r
+ Format format;\r
+ Extent3D extent;\r
+ uint32_t mipLevels;\r
+ uint32_t arrayLayers;\r
+ SampleCountFlagBits samples;\r
+ ImageTiling tiling;\r
+ ImageUsageFlags usage;\r
+ SharingMode sharingMode;\r
+ uint32_t queueFamilyIndexCount;\r
+ const uint32_t* pQueueFamilyIndices;\r
+ ImageLayout initialLayout;\r
+ };\r
+ static_assert( sizeof( ImageCreateInfo ) == sizeof( VkImageCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineMultisampleStateCreateInfo\r
+ {\r
+ PipelineMultisampleStateCreateInfo( PipelineMultisampleStateCreateFlags flags_ = PipelineMultisampleStateCreateFlags(), SampleCountFlagBits rasterizationSamples_ = SampleCountFlagBits::e1, Bool32 sampleShadingEnable_ = 0, float minSampleShading_ = 0, const SampleMask* pSampleMask_ = nullptr, Bool32 alphaToCoverageEnable_ = 0, Bool32 alphaToOneEnable_ = 0 )\r
+ : flags( flags_ )\r
+ , rasterizationSamples( rasterizationSamples_ )\r
+ , sampleShadingEnable( sampleShadingEnable_ )\r
+ , minSampleShading( minSampleShading_ )\r
+ , pSampleMask( pSampleMask_ )\r
+ , alphaToCoverageEnable( alphaToCoverageEnable_ )\r
+ , alphaToOneEnable( alphaToOneEnable_ )\r
+ {\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo( VkPipelineMultisampleStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineMultisampleStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& operator=( VkPipelineMultisampleStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineMultisampleStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineMultisampleStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setFlags( PipelineMultisampleStateCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setRasterizationSamples( SampleCountFlagBits rasterizationSamples_ )\r
+ {\r
+ rasterizationSamples = rasterizationSamples_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setSampleShadingEnable( Bool32 sampleShadingEnable_ )\r
+ {\r
+ sampleShadingEnable = sampleShadingEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setMinSampleShading( float minSampleShading_ )\r
+ {\r
+ minSampleShading = minSampleShading_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setPSampleMask( const SampleMask* pSampleMask_ )\r
+ {\r
+ pSampleMask = pSampleMask_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setAlphaToCoverageEnable( Bool32 alphaToCoverageEnable_ )\r
+ {\r
+ alphaToCoverageEnable = alphaToCoverageEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineMultisampleStateCreateInfo& setAlphaToOneEnable( Bool32 alphaToOneEnable_ )\r
+ {\r
+ alphaToOneEnable = alphaToOneEnable_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineMultisampleStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineMultisampleStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineMultisampleStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( rasterizationSamples == rhs.rasterizationSamples )\r
+ && ( sampleShadingEnable == rhs.sampleShadingEnable )\r
+ && ( minSampleShading == rhs.minSampleShading )\r
+ && ( pSampleMask == rhs.pSampleMask )\r
+ && ( alphaToCoverageEnable == rhs.alphaToCoverageEnable )\r
+ && ( alphaToOneEnable == rhs.alphaToOneEnable );\r
+ }\r
+\r
+ bool operator!=( PipelineMultisampleStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineMultisampleStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineMultisampleStateCreateFlags flags;\r
+ SampleCountFlagBits rasterizationSamples;\r
+ Bool32 sampleShadingEnable;\r
+ float minSampleShading;\r
+ const SampleMask* pSampleMask;\r
+ Bool32 alphaToCoverageEnable;\r
+ Bool32 alphaToOneEnable;\r
+ };\r
+ static_assert( sizeof( PipelineMultisampleStateCreateInfo ) == sizeof( VkPipelineMultisampleStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct GraphicsPipelineCreateInfo\r
+ {\r
+ GraphicsPipelineCreateInfo( PipelineCreateFlags flags_ = PipelineCreateFlags(), uint32_t stageCount_ = 0, const PipelineShaderStageCreateInfo* pStages_ = nullptr, const PipelineVertexInputStateCreateInfo* pVertexInputState_ = nullptr, const PipelineInputAssemblyStateCreateInfo* pInputAssemblyState_ = nullptr, const PipelineTessellationStateCreateInfo* pTessellationState_ = nullptr, const PipelineViewportStateCreateInfo* pViewportState_ = nullptr, const PipelineRasterizationStateCreateInfo* pRasterizationState_ = nullptr, const PipelineMultisampleStateCreateInfo* pMultisampleState_ = nullptr, const PipelineDepthStencilStateCreateInfo* pDepthStencilState_ = nullptr, const PipelineColorBlendStateCreateInfo* pColorBlendState_ = nullptr, const PipelineDynamicStateCreateInfo* pDynamicState_ = nullptr, PipelineLayout layout_ = PipelineLayout(), RenderPass renderPass_ = RenderPass(), uint32_t subpass_ = 0, Pipeline basePipelineHandle_ = Pipeline(), int32_t basePipelineIndex_ = 0 )\r
+ : flags( flags_ )\r
+ , stageCount( stageCount_ )\r
+ , pStages( pStages_ )\r
+ , pVertexInputState( pVertexInputState_ )\r
+ , pInputAssemblyState( pInputAssemblyState_ )\r
+ , pTessellationState( pTessellationState_ )\r
+ , pViewportState( pViewportState_ )\r
+ , pRasterizationState( pRasterizationState_ )\r
+ , pMultisampleState( pMultisampleState_ )\r
+ , pDepthStencilState( pDepthStencilState_ )\r
+ , pColorBlendState( pColorBlendState_ )\r
+ , pDynamicState( pDynamicState_ )\r
+ , layout( layout_ )\r
+ , renderPass( renderPass_ )\r
+ , subpass( subpass_ )\r
+ , basePipelineHandle( basePipelineHandle_ )\r
+ , basePipelineIndex( basePipelineIndex_ )\r
+ {\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo( VkGraphicsPipelineCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( GraphicsPipelineCreateInfo ) );\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& operator=( VkGraphicsPipelineCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( GraphicsPipelineCreateInfo ) );\r
+ return *this;\r
+ }\r
+ GraphicsPipelineCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setFlags( PipelineCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setStageCount( uint32_t stageCount_ )\r
+ {\r
+ stageCount = stageCount_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPStages( const PipelineShaderStageCreateInfo* pStages_ )\r
+ {\r
+ pStages = pStages_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPVertexInputState( const PipelineVertexInputStateCreateInfo* pVertexInputState_ )\r
+ {\r
+ pVertexInputState = pVertexInputState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPInputAssemblyState( const PipelineInputAssemblyStateCreateInfo* pInputAssemblyState_ )\r
+ {\r
+ pInputAssemblyState = pInputAssemblyState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPTessellationState( const PipelineTessellationStateCreateInfo* pTessellationState_ )\r
+ {\r
+ pTessellationState = pTessellationState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPViewportState( const PipelineViewportStateCreateInfo* pViewportState_ )\r
+ {\r
+ pViewportState = pViewportState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPRasterizationState( const PipelineRasterizationStateCreateInfo* pRasterizationState_ )\r
+ {\r
+ pRasterizationState = pRasterizationState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPMultisampleState( const PipelineMultisampleStateCreateInfo* pMultisampleState_ )\r
+ {\r
+ pMultisampleState = pMultisampleState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPDepthStencilState( const PipelineDepthStencilStateCreateInfo* pDepthStencilState_ )\r
+ {\r
+ pDepthStencilState = pDepthStencilState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPColorBlendState( const PipelineColorBlendStateCreateInfo* pColorBlendState_ )\r
+ {\r
+ pColorBlendState = pColorBlendState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setPDynamicState( const PipelineDynamicStateCreateInfo* pDynamicState_ )\r
+ {\r
+ pDynamicState = pDynamicState_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setLayout( PipelineLayout layout_ )\r
+ {\r
+ layout = layout_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setRenderPass( RenderPass renderPass_ )\r
+ {\r
+ renderPass = renderPass_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setSubpass( uint32_t subpass_ )\r
+ {\r
+ subpass = subpass_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setBasePipelineHandle( Pipeline basePipelineHandle_ )\r
+ {\r
+ basePipelineHandle = basePipelineHandle_;\r
+ return *this;\r
+ }\r
+\r
+ GraphicsPipelineCreateInfo& setBasePipelineIndex( int32_t basePipelineIndex_ )\r
+ {\r
+ basePipelineIndex = basePipelineIndex_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkGraphicsPipelineCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkGraphicsPipelineCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( GraphicsPipelineCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( stageCount == rhs.stageCount )\r
+ && ( pStages == rhs.pStages )\r
+ && ( pVertexInputState == rhs.pVertexInputState )\r
+ && ( pInputAssemblyState == rhs.pInputAssemblyState )\r
+ && ( pTessellationState == rhs.pTessellationState )\r
+ && ( pViewportState == rhs.pViewportState )\r
+ && ( pRasterizationState == rhs.pRasterizationState )\r
+ && ( pMultisampleState == rhs.pMultisampleState )\r
+ && ( pDepthStencilState == rhs.pDepthStencilState )\r
+ && ( pColorBlendState == rhs.pColorBlendState )\r
+ && ( pDynamicState == rhs.pDynamicState )\r
+ && ( layout == rhs.layout )\r
+ && ( renderPass == rhs.renderPass )\r
+ && ( subpass == rhs.subpass )\r
+ && ( basePipelineHandle == rhs.basePipelineHandle )\r
+ && ( basePipelineIndex == rhs.basePipelineIndex );\r
+ }\r
+\r
+ bool operator!=( GraphicsPipelineCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eGraphicsPipelineCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineCreateFlags flags;\r
+ uint32_t stageCount;\r
+ const PipelineShaderStageCreateInfo* pStages;\r
+ const PipelineVertexInputStateCreateInfo* pVertexInputState;\r
+ const PipelineInputAssemblyStateCreateInfo* pInputAssemblyState;\r
+ const PipelineTessellationStateCreateInfo* pTessellationState;\r
+ const PipelineViewportStateCreateInfo* pViewportState;\r
+ const PipelineRasterizationStateCreateInfo* pRasterizationState;\r
+ const PipelineMultisampleStateCreateInfo* pMultisampleState;\r
+ const PipelineDepthStencilStateCreateInfo* pDepthStencilState;\r
+ const PipelineColorBlendStateCreateInfo* pColorBlendState;\r
+ const PipelineDynamicStateCreateInfo* pDynamicState;\r
+ PipelineLayout layout;\r
+ RenderPass renderPass;\r
+ uint32_t subpass;\r
+ Pipeline basePipelineHandle;\r
+ int32_t basePipelineIndex;\r
+ };\r
+ static_assert( sizeof( GraphicsPipelineCreateInfo ) == sizeof( VkGraphicsPipelineCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceLimits\r
+ {\r
+ operator const VkPhysicalDeviceLimits&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceLimits*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceLimits const& rhs ) const\r
+ {\r
+ return ( maxImageDimension1D == rhs.maxImageDimension1D )\r
+ && ( maxImageDimension2D == rhs.maxImageDimension2D )\r
+ && ( maxImageDimension3D == rhs.maxImageDimension3D )\r
+ && ( maxImageDimensionCube == rhs.maxImageDimensionCube )\r
+ && ( maxImageArrayLayers == rhs.maxImageArrayLayers )\r
+ && ( maxTexelBufferElements == rhs.maxTexelBufferElements )\r
+ && ( maxUniformBufferRange == rhs.maxUniformBufferRange )\r
+ && ( maxStorageBufferRange == rhs.maxStorageBufferRange )\r
+ && ( maxPushConstantsSize == rhs.maxPushConstantsSize )\r
+ && ( maxMemoryAllocationCount == rhs.maxMemoryAllocationCount )\r
+ && ( maxSamplerAllocationCount == rhs.maxSamplerAllocationCount )\r
+ && ( bufferImageGranularity == rhs.bufferImageGranularity )\r
+ && ( sparseAddressSpaceSize == rhs.sparseAddressSpaceSize )\r
+ && ( maxBoundDescriptorSets == rhs.maxBoundDescriptorSets )\r
+ && ( maxPerStageDescriptorSamplers == rhs.maxPerStageDescriptorSamplers )\r
+ && ( maxPerStageDescriptorUniformBuffers == rhs.maxPerStageDescriptorUniformBuffers )\r
+ && ( maxPerStageDescriptorStorageBuffers == rhs.maxPerStageDescriptorStorageBuffers )\r
+ && ( maxPerStageDescriptorSampledImages == rhs.maxPerStageDescriptorSampledImages )\r
+ && ( maxPerStageDescriptorStorageImages == rhs.maxPerStageDescriptorStorageImages )\r
+ && ( maxPerStageDescriptorInputAttachments == rhs.maxPerStageDescriptorInputAttachments )\r
+ && ( maxPerStageResources == rhs.maxPerStageResources )\r
+ && ( maxDescriptorSetSamplers == rhs.maxDescriptorSetSamplers )\r
+ && ( maxDescriptorSetUniformBuffers == rhs.maxDescriptorSetUniformBuffers )\r
+ && ( maxDescriptorSetUniformBuffersDynamic == rhs.maxDescriptorSetUniformBuffersDynamic )\r
+ && ( maxDescriptorSetStorageBuffers == rhs.maxDescriptorSetStorageBuffers )\r
+ && ( maxDescriptorSetStorageBuffersDynamic == rhs.maxDescriptorSetStorageBuffersDynamic )\r
+ && ( maxDescriptorSetSampledImages == rhs.maxDescriptorSetSampledImages )\r
+ && ( maxDescriptorSetStorageImages == rhs.maxDescriptorSetStorageImages )\r
+ && ( maxDescriptorSetInputAttachments == rhs.maxDescriptorSetInputAttachments )\r
+ && ( maxVertexInputAttributes == rhs.maxVertexInputAttributes )\r
+ && ( maxVertexInputBindings == rhs.maxVertexInputBindings )\r
+ && ( maxVertexInputAttributeOffset == rhs.maxVertexInputAttributeOffset )\r
+ && ( maxVertexInputBindingStride == rhs.maxVertexInputBindingStride )\r
+ && ( maxVertexOutputComponents == rhs.maxVertexOutputComponents )\r
+ && ( maxTessellationGenerationLevel == rhs.maxTessellationGenerationLevel )\r
+ && ( maxTessellationPatchSize == rhs.maxTessellationPatchSize )\r
+ && ( maxTessellationControlPerVertexInputComponents == rhs.maxTessellationControlPerVertexInputComponents )\r
+ && ( maxTessellationControlPerVertexOutputComponents == rhs.maxTessellationControlPerVertexOutputComponents )\r
+ && ( maxTessellationControlPerPatchOutputComponents == rhs.maxTessellationControlPerPatchOutputComponents )\r
+ && ( maxTessellationControlTotalOutputComponents == rhs.maxTessellationControlTotalOutputComponents )\r
+ && ( maxTessellationEvaluationInputComponents == rhs.maxTessellationEvaluationInputComponents )\r
+ && ( maxTessellationEvaluationOutputComponents == rhs.maxTessellationEvaluationOutputComponents )\r
+ && ( maxGeometryShaderInvocations == rhs.maxGeometryShaderInvocations )\r
+ && ( maxGeometryInputComponents == rhs.maxGeometryInputComponents )\r
+ && ( maxGeometryOutputComponents == rhs.maxGeometryOutputComponents )\r
+ && ( maxGeometryOutputVertices == rhs.maxGeometryOutputVertices )\r
+ && ( maxGeometryTotalOutputComponents == rhs.maxGeometryTotalOutputComponents )\r
+ && ( maxFragmentInputComponents == rhs.maxFragmentInputComponents )\r
+ && ( maxFragmentOutputAttachments == rhs.maxFragmentOutputAttachments )\r
+ && ( maxFragmentDualSrcAttachments == rhs.maxFragmentDualSrcAttachments )\r
+ && ( maxFragmentCombinedOutputResources == rhs.maxFragmentCombinedOutputResources )\r
+ && ( maxComputeSharedMemorySize == rhs.maxComputeSharedMemorySize )\r
+ && ( memcmp( maxComputeWorkGroupCount, rhs.maxComputeWorkGroupCount, 3 * sizeof( uint32_t ) ) == 0 )\r
+ && ( maxComputeWorkGroupInvocations == rhs.maxComputeWorkGroupInvocations )\r
+ && ( memcmp( maxComputeWorkGroupSize, rhs.maxComputeWorkGroupSize, 3 * sizeof( uint32_t ) ) == 0 )\r
+ && ( subPixelPrecisionBits == rhs.subPixelPrecisionBits )\r
+ && ( subTexelPrecisionBits == rhs.subTexelPrecisionBits )\r
+ && ( mipmapPrecisionBits == rhs.mipmapPrecisionBits )\r
+ && ( maxDrawIndexedIndexValue == rhs.maxDrawIndexedIndexValue )\r
+ && ( maxDrawIndirectCount == rhs.maxDrawIndirectCount )\r
+ && ( maxSamplerLodBias == rhs.maxSamplerLodBias )\r
+ && ( maxSamplerAnisotropy == rhs.maxSamplerAnisotropy )\r
+ && ( maxViewports == rhs.maxViewports )\r
+ && ( memcmp( maxViewportDimensions, rhs.maxViewportDimensions, 2 * sizeof( uint32_t ) ) == 0 )\r
+ && ( memcmp( viewportBoundsRange, rhs.viewportBoundsRange, 2 * sizeof( float ) ) == 0 )\r
+ && ( viewportSubPixelBits == rhs.viewportSubPixelBits )\r
+ && ( minMemoryMapAlignment == rhs.minMemoryMapAlignment )\r
+ && ( minTexelBufferOffsetAlignment == rhs.minTexelBufferOffsetAlignment )\r
+ && ( minUniformBufferOffsetAlignment == rhs.minUniformBufferOffsetAlignment )\r
+ && ( minStorageBufferOffsetAlignment == rhs.minStorageBufferOffsetAlignment )\r
+ && ( minTexelOffset == rhs.minTexelOffset )\r
+ && ( maxTexelOffset == rhs.maxTexelOffset )\r
+ && ( minTexelGatherOffset == rhs.minTexelGatherOffset )\r
+ && ( maxTexelGatherOffset == rhs.maxTexelGatherOffset )\r
+ && ( minInterpolationOffset == rhs.minInterpolationOffset )\r
+ && ( maxInterpolationOffset == rhs.maxInterpolationOffset )\r
+ && ( subPixelInterpolationOffsetBits == rhs.subPixelInterpolationOffsetBits )\r
+ && ( maxFramebufferWidth == rhs.maxFramebufferWidth )\r
+ && ( maxFramebufferHeight == rhs.maxFramebufferHeight )\r
+ && ( maxFramebufferLayers == rhs.maxFramebufferLayers )\r
+ && ( framebufferColorSampleCounts == rhs.framebufferColorSampleCounts )\r
+ && ( framebufferDepthSampleCounts == rhs.framebufferDepthSampleCounts )\r
+ && ( framebufferStencilSampleCounts == rhs.framebufferStencilSampleCounts )\r
+ && ( framebufferNoAttachmentsSampleCounts == rhs.framebufferNoAttachmentsSampleCounts )\r
+ && ( maxColorAttachments == rhs.maxColorAttachments )\r
+ && ( sampledImageColorSampleCounts == rhs.sampledImageColorSampleCounts )\r
+ && ( sampledImageIntegerSampleCounts == rhs.sampledImageIntegerSampleCounts )\r
+ && ( sampledImageDepthSampleCounts == rhs.sampledImageDepthSampleCounts )\r
+ && ( sampledImageStencilSampleCounts == rhs.sampledImageStencilSampleCounts )\r
+ && ( storageImageSampleCounts == rhs.storageImageSampleCounts )\r
+ && ( maxSampleMaskWords == rhs.maxSampleMaskWords )\r
+ && ( timestampComputeAndGraphics == rhs.timestampComputeAndGraphics )\r
+ && ( timestampPeriod == rhs.timestampPeriod )\r
+ && ( maxClipDistances == rhs.maxClipDistances )\r
+ && ( maxCullDistances == rhs.maxCullDistances )\r
+ && ( maxCombinedClipAndCullDistances == rhs.maxCombinedClipAndCullDistances )\r
+ && ( discreteQueuePriorities == rhs.discreteQueuePriorities )\r
+ && ( memcmp( pointSizeRange, rhs.pointSizeRange, 2 * sizeof( float ) ) == 0 )\r
+ && ( memcmp( lineWidthRange, rhs.lineWidthRange, 2 * sizeof( float ) ) == 0 )\r
+ && ( pointSizeGranularity == rhs.pointSizeGranularity )\r
+ && ( lineWidthGranularity == rhs.lineWidthGranularity )\r
+ && ( strictLines == rhs.strictLines )\r
+ && ( standardSampleLocations == rhs.standardSampleLocations )\r
+ && ( optimalBufferCopyOffsetAlignment == rhs.optimalBufferCopyOffsetAlignment )\r
+ && ( optimalBufferCopyRowPitchAlignment == rhs.optimalBufferCopyRowPitchAlignment )\r
+ && ( nonCoherentAtomSize == rhs.nonCoherentAtomSize );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceLimits const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t maxImageDimension1D;\r
+ uint32_t maxImageDimension2D;\r
+ uint32_t maxImageDimension3D;\r
+ uint32_t maxImageDimensionCube;\r
+ uint32_t maxImageArrayLayers;\r
+ uint32_t maxTexelBufferElements;\r
+ uint32_t maxUniformBufferRange;\r
+ uint32_t maxStorageBufferRange;\r
+ uint32_t maxPushConstantsSize;\r
+ uint32_t maxMemoryAllocationCount;\r
+ uint32_t maxSamplerAllocationCount;\r
+ DeviceSize bufferImageGranularity;\r
+ DeviceSize sparseAddressSpaceSize;\r
+ uint32_t maxBoundDescriptorSets;\r
+ uint32_t maxPerStageDescriptorSamplers;\r
+ uint32_t maxPerStageDescriptorUniformBuffers;\r
+ uint32_t maxPerStageDescriptorStorageBuffers;\r
+ uint32_t maxPerStageDescriptorSampledImages;\r
+ uint32_t maxPerStageDescriptorStorageImages;\r
+ uint32_t maxPerStageDescriptorInputAttachments;\r
+ uint32_t maxPerStageResources;\r
+ uint32_t maxDescriptorSetSamplers;\r
+ uint32_t maxDescriptorSetUniformBuffers;\r
+ uint32_t maxDescriptorSetUniformBuffersDynamic;\r
+ uint32_t maxDescriptorSetStorageBuffers;\r
+ uint32_t maxDescriptorSetStorageBuffersDynamic;\r
+ uint32_t maxDescriptorSetSampledImages;\r
+ uint32_t maxDescriptorSetStorageImages;\r
+ uint32_t maxDescriptorSetInputAttachments;\r
+ uint32_t maxVertexInputAttributes;\r
+ uint32_t maxVertexInputBindings;\r
+ uint32_t maxVertexInputAttributeOffset;\r
+ uint32_t maxVertexInputBindingStride;\r
+ uint32_t maxVertexOutputComponents;\r
+ uint32_t maxTessellationGenerationLevel;\r
+ uint32_t maxTessellationPatchSize;\r
+ uint32_t maxTessellationControlPerVertexInputComponents;\r
+ uint32_t maxTessellationControlPerVertexOutputComponents;\r
+ uint32_t maxTessellationControlPerPatchOutputComponents;\r
+ uint32_t maxTessellationControlTotalOutputComponents;\r
+ uint32_t maxTessellationEvaluationInputComponents;\r
+ uint32_t maxTessellationEvaluationOutputComponents;\r
+ uint32_t maxGeometryShaderInvocations;\r
+ uint32_t maxGeometryInputComponents;\r
+ uint32_t maxGeometryOutputComponents;\r
+ uint32_t maxGeometryOutputVertices;\r
+ uint32_t maxGeometryTotalOutputComponents;\r
+ uint32_t maxFragmentInputComponents;\r
+ uint32_t maxFragmentOutputAttachments;\r
+ uint32_t maxFragmentDualSrcAttachments;\r
+ uint32_t maxFragmentCombinedOutputResources;\r
+ uint32_t maxComputeSharedMemorySize;\r
+ uint32_t maxComputeWorkGroupCount[3];\r
+ uint32_t maxComputeWorkGroupInvocations;\r
+ uint32_t maxComputeWorkGroupSize[3];\r
+ uint32_t subPixelPrecisionBits;\r
+ uint32_t subTexelPrecisionBits;\r
+ uint32_t mipmapPrecisionBits;\r
+ uint32_t maxDrawIndexedIndexValue;\r
+ uint32_t maxDrawIndirectCount;\r
+ float maxSamplerLodBias;\r
+ float maxSamplerAnisotropy;\r
+ uint32_t maxViewports;\r
+ uint32_t maxViewportDimensions[2];\r
+ float viewportBoundsRange[2];\r
+ uint32_t viewportSubPixelBits;\r
+ size_t minMemoryMapAlignment;\r
+ DeviceSize minTexelBufferOffsetAlignment;\r
+ DeviceSize minUniformBufferOffsetAlignment;\r
+ DeviceSize minStorageBufferOffsetAlignment;\r
+ int32_t minTexelOffset;\r
+ uint32_t maxTexelOffset;\r
+ int32_t minTexelGatherOffset;\r
+ uint32_t maxTexelGatherOffset;\r
+ float minInterpolationOffset;\r
+ float maxInterpolationOffset;\r
+ uint32_t subPixelInterpolationOffsetBits;\r
+ uint32_t maxFramebufferWidth;\r
+ uint32_t maxFramebufferHeight;\r
+ uint32_t maxFramebufferLayers;\r
+ SampleCountFlags framebufferColorSampleCounts;\r
+ SampleCountFlags framebufferDepthSampleCounts;\r
+ SampleCountFlags framebufferStencilSampleCounts;\r
+ SampleCountFlags framebufferNoAttachmentsSampleCounts;\r
+ uint32_t maxColorAttachments;\r
+ SampleCountFlags sampledImageColorSampleCounts;\r
+ SampleCountFlags sampledImageIntegerSampleCounts;\r
+ SampleCountFlags sampledImageDepthSampleCounts;\r
+ SampleCountFlags sampledImageStencilSampleCounts;\r
+ SampleCountFlags storageImageSampleCounts;\r
+ uint32_t maxSampleMaskWords;\r
+ Bool32 timestampComputeAndGraphics;\r
+ float timestampPeriod;\r
+ uint32_t maxClipDistances;\r
+ uint32_t maxCullDistances;\r
+ uint32_t maxCombinedClipAndCullDistances;\r
+ uint32_t discreteQueuePriorities;\r
+ float pointSizeRange[2];\r
+ float lineWidthRange[2];\r
+ float pointSizeGranularity;\r
+ float lineWidthGranularity;\r
+ Bool32 strictLines;\r
+ Bool32 standardSampleLocations;\r
+ DeviceSize optimalBufferCopyOffsetAlignment;\r
+ DeviceSize optimalBufferCopyRowPitchAlignment;\r
+ DeviceSize nonCoherentAtomSize;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceLimits ) == sizeof( VkPhysicalDeviceLimits ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceProperties\r
+ {\r
+ operator const VkPhysicalDeviceProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceProperties const& rhs ) const\r
+ {\r
+ return ( apiVersion == rhs.apiVersion )\r
+ && ( driverVersion == rhs.driverVersion )\r
+ && ( vendorID == rhs.vendorID )\r
+ && ( deviceID == rhs.deviceID )\r
+ && ( deviceType == rhs.deviceType )\r
+ && ( memcmp( deviceName, rhs.deviceName, VK_MAX_PHYSICAL_DEVICE_NAME_SIZE * sizeof( char ) ) == 0 )\r
+ && ( memcmp( pipelineCacheUUID, rhs.pipelineCacheUUID, VK_UUID_SIZE * sizeof( uint8_t ) ) == 0 )\r
+ && ( limits == rhs.limits )\r
+ && ( sparseProperties == rhs.sparseProperties );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t apiVersion;\r
+ uint32_t driverVersion;\r
+ uint32_t vendorID;\r
+ uint32_t deviceID;\r
+ PhysicalDeviceType deviceType;\r
+ char deviceName[VK_MAX_PHYSICAL_DEVICE_NAME_SIZE];\r
+ uint8_t pipelineCacheUUID[VK_UUID_SIZE];\r
+ PhysicalDeviceLimits limits;\r
+ PhysicalDeviceSparseProperties sparseProperties;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceProperties ) == sizeof( VkPhysicalDeviceProperties ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceProperties2\r
+ {\r
+ operator const VkPhysicalDeviceProperties2&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceProperties2*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceProperties2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( properties == rhs.properties );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceProperties2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceProperties2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ PhysicalDeviceProperties properties;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceProperties2 ) == sizeof( VkPhysicalDeviceProperties2 ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceProperties2KHR = PhysicalDeviceProperties2;\r
+\r
+ struct ImageFormatProperties2\r
+ {\r
+ operator const VkImageFormatProperties2&() const\r
+ {\r
+ return *reinterpret_cast<const VkImageFormatProperties2*>(this);\r
+ }\r
+\r
+ bool operator==( ImageFormatProperties2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( imageFormatProperties == rhs.imageFormatProperties );\r
+ }\r
+\r
+ bool operator!=( ImageFormatProperties2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImageFormatProperties2;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ ImageFormatProperties imageFormatProperties;\r
+ };\r
+ static_assert( sizeof( ImageFormatProperties2 ) == sizeof( VkImageFormatProperties2 ), "struct and wrapper have different size!" );\r
+\r
+ using ImageFormatProperties2KHR = ImageFormatProperties2;\r
+\r
+ struct PhysicalDeviceSparseImageFormatInfo2\r
+ {\r
+ PhysicalDeviceSparseImageFormatInfo2( Format format_ = Format::eUndefined, ImageType type_ = ImageType::e1D, SampleCountFlagBits samples_ = SampleCountFlagBits::e1, ImageUsageFlags usage_ = ImageUsageFlags(), ImageTiling tiling_ = ImageTiling::eOptimal )\r
+ : format( format_ )\r
+ , type( type_ )\r
+ , samples( samples_ )\r
+ , usage( usage_ )\r
+ , tiling( tiling_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2( VkPhysicalDeviceSparseImageFormatInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceSparseImageFormatInfo2 ) );\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2& operator=( VkPhysicalDeviceSparseImageFormatInfo2 const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceSparseImageFormatInfo2 ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceSparseImageFormatInfo2& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2& setType( ImageType type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2& setSamples( SampleCountFlagBits samples_ )\r
+ {\r
+ samples = samples_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2& setUsage( ImageUsageFlags usage_ )\r
+ {\r
+ usage = usage_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceSparseImageFormatInfo2& setTiling( ImageTiling tiling_ )\r
+ {\r
+ tiling = tiling_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceSparseImageFormatInfo2&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSparseImageFormatInfo2 const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( format == rhs.format )\r
+ && ( type == rhs.type )\r
+ && ( samples == rhs.samples )\r
+ && ( usage == rhs.usage )\r
+ && ( tiling == rhs.tiling );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSparseImageFormatInfo2 const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceSparseImageFormatInfo2;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Format format;\r
+ ImageType type;\r
+ SampleCountFlagBits samples;\r
+ ImageUsageFlags usage;\r
+ ImageTiling tiling;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSparseImageFormatInfo2 ) == sizeof( VkPhysicalDeviceSparseImageFormatInfo2 ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceSparseImageFormatInfo2KHR = PhysicalDeviceSparseImageFormatInfo2;\r
+\r
+ struct SampleLocationsInfoEXT\r
+ {\r
+ SampleLocationsInfoEXT( SampleCountFlagBits sampleLocationsPerPixel_ = SampleCountFlagBits::e1, Extent2D sampleLocationGridSize_ = Extent2D(), uint32_t sampleLocationsCount_ = 0, const SampleLocationEXT* pSampleLocations_ = nullptr )\r
+ : sampleLocationsPerPixel( sampleLocationsPerPixel_ )\r
+ , sampleLocationGridSize( sampleLocationGridSize_ )\r
+ , sampleLocationsCount( sampleLocationsCount_ )\r
+ , pSampleLocations( pSampleLocations_ )\r
+ {\r
+ }\r
+\r
+ SampleLocationsInfoEXT( VkSampleLocationsInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SampleLocationsInfoEXT ) );\r
+ }\r
+\r
+ SampleLocationsInfoEXT& operator=( VkSampleLocationsInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SampleLocationsInfoEXT ) );\r
+ return *this;\r
+ }\r
+ SampleLocationsInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SampleLocationsInfoEXT& setSampleLocationsPerPixel( SampleCountFlagBits sampleLocationsPerPixel_ )\r
+ {\r
+ sampleLocationsPerPixel = sampleLocationsPerPixel_;\r
+ return *this;\r
+ }\r
+\r
+ SampleLocationsInfoEXT& setSampleLocationGridSize( Extent2D sampleLocationGridSize_ )\r
+ {\r
+ sampleLocationGridSize = sampleLocationGridSize_;\r
+ return *this;\r
+ }\r
+\r
+ SampleLocationsInfoEXT& setSampleLocationsCount( uint32_t sampleLocationsCount_ )\r
+ {\r
+ sampleLocationsCount = sampleLocationsCount_;\r
+ return *this;\r
+ }\r
+\r
+ SampleLocationsInfoEXT& setPSampleLocations( const SampleLocationEXT* pSampleLocations_ )\r
+ {\r
+ pSampleLocations = pSampleLocations_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSampleLocationsInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkSampleLocationsInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( SampleLocationsInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( sampleLocationsPerPixel == rhs.sampleLocationsPerPixel )\r
+ && ( sampleLocationGridSize == rhs.sampleLocationGridSize )\r
+ && ( sampleLocationsCount == rhs.sampleLocationsCount )\r
+ && ( pSampleLocations == rhs.pSampleLocations );\r
+ }\r
+\r
+ bool operator!=( SampleLocationsInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSampleLocationsInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SampleCountFlagBits sampleLocationsPerPixel;\r
+ Extent2D sampleLocationGridSize;\r
+ uint32_t sampleLocationsCount;\r
+ const SampleLocationEXT* pSampleLocations;\r
+ };\r
+ static_assert( sizeof( SampleLocationsInfoEXT ) == sizeof( VkSampleLocationsInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct AttachmentSampleLocationsEXT\r
+ {\r
+ AttachmentSampleLocationsEXT( uint32_t attachmentIndex_ = 0, SampleLocationsInfoEXT sampleLocationsInfo_ = SampleLocationsInfoEXT() )\r
+ : attachmentIndex( attachmentIndex_ )\r
+ , sampleLocationsInfo( sampleLocationsInfo_ )\r
+ {\r
+ }\r
+\r
+ AttachmentSampleLocationsEXT( VkAttachmentSampleLocationsEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AttachmentSampleLocationsEXT ) );\r
+ }\r
+\r
+ AttachmentSampleLocationsEXT& operator=( VkAttachmentSampleLocationsEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AttachmentSampleLocationsEXT ) );\r
+ return *this;\r
+ }\r
+ AttachmentSampleLocationsEXT& setAttachmentIndex( uint32_t attachmentIndex_ )\r
+ {\r
+ attachmentIndex = attachmentIndex_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentSampleLocationsEXT& setSampleLocationsInfo( SampleLocationsInfoEXT sampleLocationsInfo_ )\r
+ {\r
+ sampleLocationsInfo = sampleLocationsInfo_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkAttachmentSampleLocationsEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkAttachmentSampleLocationsEXT*>(this);\r
+ }\r
+\r
+ bool operator==( AttachmentSampleLocationsEXT const& rhs ) const\r
+ {\r
+ return ( attachmentIndex == rhs.attachmentIndex )\r
+ && ( sampleLocationsInfo == rhs.sampleLocationsInfo );\r
+ }\r
+\r
+ bool operator!=( AttachmentSampleLocationsEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t attachmentIndex;\r
+ SampleLocationsInfoEXT sampleLocationsInfo;\r
+ };\r
+ static_assert( sizeof( AttachmentSampleLocationsEXT ) == sizeof( VkAttachmentSampleLocationsEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct SubpassSampleLocationsEXT\r
+ {\r
+ SubpassSampleLocationsEXT( uint32_t subpassIndex_ = 0, SampleLocationsInfoEXT sampleLocationsInfo_ = SampleLocationsInfoEXT() )\r
+ : subpassIndex( subpassIndex_ )\r
+ , sampleLocationsInfo( sampleLocationsInfo_ )\r
+ {\r
+ }\r
+\r
+ SubpassSampleLocationsEXT( VkSubpassSampleLocationsEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubpassSampleLocationsEXT ) );\r
+ }\r
+\r
+ SubpassSampleLocationsEXT& operator=( VkSubpassSampleLocationsEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubpassSampleLocationsEXT ) );\r
+ return *this;\r
+ }\r
+ SubpassSampleLocationsEXT& setSubpassIndex( uint32_t subpassIndex_ )\r
+ {\r
+ subpassIndex = subpassIndex_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassSampleLocationsEXT& setSampleLocationsInfo( SampleLocationsInfoEXT sampleLocationsInfo_ )\r
+ {\r
+ sampleLocationsInfo = sampleLocationsInfo_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSubpassSampleLocationsEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkSubpassSampleLocationsEXT*>(this);\r
+ }\r
+\r
+ bool operator==( SubpassSampleLocationsEXT const& rhs ) const\r
+ {\r
+ return ( subpassIndex == rhs.subpassIndex )\r
+ && ( sampleLocationsInfo == rhs.sampleLocationsInfo );\r
+ }\r
+\r
+ bool operator!=( SubpassSampleLocationsEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t subpassIndex;\r
+ SampleLocationsInfoEXT sampleLocationsInfo;\r
+ };\r
+ static_assert( sizeof( SubpassSampleLocationsEXT ) == sizeof( VkSubpassSampleLocationsEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct RenderPassSampleLocationsBeginInfoEXT\r
+ {\r
+ RenderPassSampleLocationsBeginInfoEXT( uint32_t attachmentInitialSampleLocationsCount_ = 0, const AttachmentSampleLocationsEXT* pAttachmentInitialSampleLocations_ = nullptr, uint32_t postSubpassSampleLocationsCount_ = 0, const SubpassSampleLocationsEXT* pPostSubpassSampleLocations_ = nullptr )\r
+ : attachmentInitialSampleLocationsCount( attachmentInitialSampleLocationsCount_ )\r
+ , pAttachmentInitialSampleLocations( pAttachmentInitialSampleLocations_ )\r
+ , postSubpassSampleLocationsCount( postSubpassSampleLocationsCount_ )\r
+ , pPostSubpassSampleLocations( pPostSubpassSampleLocations_ )\r
+ {\r
+ }\r
+\r
+ RenderPassSampleLocationsBeginInfoEXT( VkRenderPassSampleLocationsBeginInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassSampleLocationsBeginInfoEXT ) );\r
+ }\r
+\r
+ RenderPassSampleLocationsBeginInfoEXT& operator=( VkRenderPassSampleLocationsBeginInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassSampleLocationsBeginInfoEXT ) );\r
+ return *this;\r
+ }\r
+ RenderPassSampleLocationsBeginInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassSampleLocationsBeginInfoEXT& setAttachmentInitialSampleLocationsCount( uint32_t attachmentInitialSampleLocationsCount_ )\r
+ {\r
+ attachmentInitialSampleLocationsCount = attachmentInitialSampleLocationsCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassSampleLocationsBeginInfoEXT& setPAttachmentInitialSampleLocations( const AttachmentSampleLocationsEXT* pAttachmentInitialSampleLocations_ )\r
+ {\r
+ pAttachmentInitialSampleLocations = pAttachmentInitialSampleLocations_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassSampleLocationsBeginInfoEXT& setPostSubpassSampleLocationsCount( uint32_t postSubpassSampleLocationsCount_ )\r
+ {\r
+ postSubpassSampleLocationsCount = postSubpassSampleLocationsCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassSampleLocationsBeginInfoEXT& setPPostSubpassSampleLocations( const SubpassSampleLocationsEXT* pPostSubpassSampleLocations_ )\r
+ {\r
+ pPostSubpassSampleLocations = pPostSubpassSampleLocations_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRenderPassSampleLocationsBeginInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkRenderPassSampleLocationsBeginInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( RenderPassSampleLocationsBeginInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( attachmentInitialSampleLocationsCount == rhs.attachmentInitialSampleLocationsCount )\r
+ && ( pAttachmentInitialSampleLocations == rhs.pAttachmentInitialSampleLocations )\r
+ && ( postSubpassSampleLocationsCount == rhs.postSubpassSampleLocationsCount )\r
+ && ( pPostSubpassSampleLocations == rhs.pPostSubpassSampleLocations );\r
+ }\r
+\r
+ bool operator!=( RenderPassSampleLocationsBeginInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eRenderPassSampleLocationsBeginInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t attachmentInitialSampleLocationsCount;\r
+ const AttachmentSampleLocationsEXT* pAttachmentInitialSampleLocations;\r
+ uint32_t postSubpassSampleLocationsCount;\r
+ const SubpassSampleLocationsEXT* pPostSubpassSampleLocations;\r
+ };\r
+ static_assert( sizeof( RenderPassSampleLocationsBeginInfoEXT ) == sizeof( VkRenderPassSampleLocationsBeginInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineSampleLocationsStateCreateInfoEXT\r
+ {\r
+ PipelineSampleLocationsStateCreateInfoEXT( Bool32 sampleLocationsEnable_ = 0, SampleLocationsInfoEXT sampleLocationsInfo_ = SampleLocationsInfoEXT() )\r
+ : sampleLocationsEnable( sampleLocationsEnable_ )\r
+ , sampleLocationsInfo( sampleLocationsInfo_ )\r
+ {\r
+ }\r
+\r
+ PipelineSampleLocationsStateCreateInfoEXT( VkPipelineSampleLocationsStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineSampleLocationsStateCreateInfoEXT ) );\r
+ }\r
+\r
+ PipelineSampleLocationsStateCreateInfoEXT& operator=( VkPipelineSampleLocationsStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineSampleLocationsStateCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ PipelineSampleLocationsStateCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineSampleLocationsStateCreateInfoEXT& setSampleLocationsEnable( Bool32 sampleLocationsEnable_ )\r
+ {\r
+ sampleLocationsEnable = sampleLocationsEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineSampleLocationsStateCreateInfoEXT& setSampleLocationsInfo( SampleLocationsInfoEXT sampleLocationsInfo_ )\r
+ {\r
+ sampleLocationsInfo = sampleLocationsInfo_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineSampleLocationsStateCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineSampleLocationsStateCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineSampleLocationsStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( sampleLocationsEnable == rhs.sampleLocationsEnable )\r
+ && ( sampleLocationsInfo == rhs.sampleLocationsInfo );\r
+ }\r
+\r
+ bool operator!=( PipelineSampleLocationsStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineSampleLocationsStateCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 sampleLocationsEnable;\r
+ SampleLocationsInfoEXT sampleLocationsInfo;\r
+ };\r
+ static_assert( sizeof( PipelineSampleLocationsStateCreateInfoEXT ) == sizeof( VkPipelineSampleLocationsStateCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceSampleLocationsPropertiesEXT\r
+ {\r
+ operator const VkPhysicalDeviceSampleLocationsPropertiesEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSampleLocationsPropertiesEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSampleLocationsPropertiesEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( sampleLocationSampleCounts == rhs.sampleLocationSampleCounts )\r
+ && ( maxSampleLocationGridSize == rhs.maxSampleLocationGridSize )\r
+ && ( memcmp( sampleLocationCoordinateRange, rhs.sampleLocationCoordinateRange, 2 * sizeof( float ) ) == 0 )\r
+ && ( sampleLocationSubPixelBits == rhs.sampleLocationSubPixelBits )\r
+ && ( variableSampleLocations == rhs.variableSampleLocations );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSampleLocationsPropertiesEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceSampleLocationsPropertiesEXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ SampleCountFlags sampleLocationSampleCounts;\r
+ Extent2D maxSampleLocationGridSize;\r
+ float sampleLocationCoordinateRange[2];\r
+ uint32_t sampleLocationSubPixelBits;\r
+ Bool32 variableSampleLocations;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSampleLocationsPropertiesEXT ) == sizeof( VkPhysicalDeviceSampleLocationsPropertiesEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class AttachmentDescriptionFlagBits\r
+ {\r
+ eMayAlias = VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT\r
+ };\r
+\r
+ using AttachmentDescriptionFlags = Flags<AttachmentDescriptionFlagBits, VkAttachmentDescriptionFlags>;\r
+\r
+ VULKAN_HPP_INLINE AttachmentDescriptionFlags operator|( AttachmentDescriptionFlagBits bit0, AttachmentDescriptionFlagBits bit1 )\r
+ {\r
+ return AttachmentDescriptionFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE AttachmentDescriptionFlags operator~( AttachmentDescriptionFlagBits bits )\r
+ {\r
+ return ~( AttachmentDescriptionFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<AttachmentDescriptionFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(AttachmentDescriptionFlagBits::eMayAlias)\r
+ };\r
+ };\r
+\r
+ struct AttachmentDescription\r
+ {\r
+ AttachmentDescription( AttachmentDescriptionFlags flags_ = AttachmentDescriptionFlags(), Format format_ = Format::eUndefined, SampleCountFlagBits samples_ = SampleCountFlagBits::e1, AttachmentLoadOp loadOp_ = AttachmentLoadOp::eLoad, AttachmentStoreOp storeOp_ = AttachmentStoreOp::eStore, AttachmentLoadOp stencilLoadOp_ = AttachmentLoadOp::eLoad, AttachmentStoreOp stencilStoreOp_ = AttachmentStoreOp::eStore, ImageLayout initialLayout_ = ImageLayout::eUndefined, ImageLayout finalLayout_ = ImageLayout::eUndefined )\r
+ : flags( flags_ )\r
+ , format( format_ )\r
+ , samples( samples_ )\r
+ , loadOp( loadOp_ )\r
+ , storeOp( storeOp_ )\r
+ , stencilLoadOp( stencilLoadOp_ )\r
+ , stencilStoreOp( stencilStoreOp_ )\r
+ , initialLayout( initialLayout_ )\r
+ , finalLayout( finalLayout_ )\r
+ {\r
+ }\r
+\r
+ AttachmentDescription( VkAttachmentDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AttachmentDescription ) );\r
+ }\r
+\r
+ AttachmentDescription& operator=( VkAttachmentDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( AttachmentDescription ) );\r
+ return *this;\r
+ }\r
+ AttachmentDescription& setFlags( AttachmentDescriptionFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setSamples( SampleCountFlagBits samples_ )\r
+ {\r
+ samples = samples_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setLoadOp( AttachmentLoadOp loadOp_ )\r
+ {\r
+ loadOp = loadOp_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setStoreOp( AttachmentStoreOp storeOp_ )\r
+ {\r
+ storeOp = storeOp_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setStencilLoadOp( AttachmentLoadOp stencilLoadOp_ )\r
+ {\r
+ stencilLoadOp = stencilLoadOp_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setStencilStoreOp( AttachmentStoreOp stencilStoreOp_ )\r
+ {\r
+ stencilStoreOp = stencilStoreOp_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setInitialLayout( ImageLayout initialLayout_ )\r
+ {\r
+ initialLayout = initialLayout_;\r
+ return *this;\r
+ }\r
+\r
+ AttachmentDescription& setFinalLayout( ImageLayout finalLayout_ )\r
+ {\r
+ finalLayout = finalLayout_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkAttachmentDescription&() const\r
+ {\r
+ return *reinterpret_cast<const VkAttachmentDescription*>(this);\r
+ }\r
+\r
+ bool operator==( AttachmentDescription const& rhs ) const\r
+ {\r
+ return ( flags == rhs.flags )\r
+ && ( format == rhs.format )\r
+ && ( samples == rhs.samples )\r
+ && ( loadOp == rhs.loadOp )\r
+ && ( storeOp == rhs.storeOp )\r
+ && ( stencilLoadOp == rhs.stencilLoadOp )\r
+ && ( stencilStoreOp == rhs.stencilStoreOp )\r
+ && ( initialLayout == rhs.initialLayout )\r
+ && ( finalLayout == rhs.finalLayout );\r
+ }\r
+\r
+ bool operator!=( AttachmentDescription const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ AttachmentDescriptionFlags flags;\r
+ Format format;\r
+ SampleCountFlagBits samples;\r
+ AttachmentLoadOp loadOp;\r
+ AttachmentStoreOp storeOp;\r
+ AttachmentLoadOp stencilLoadOp;\r
+ AttachmentStoreOp stencilStoreOp;\r
+ ImageLayout initialLayout;\r
+ ImageLayout finalLayout;\r
+ };\r
+ static_assert( sizeof( AttachmentDescription ) == sizeof( VkAttachmentDescription ), "struct and wrapper have different size!" );\r
+\r
+ enum class StencilFaceFlagBits\r
+ {\r
+ eFront = VK_STENCIL_FACE_FRONT_BIT,\r
+ eBack = VK_STENCIL_FACE_BACK_BIT,\r
+ eVkStencilFrontAndBack = VK_STENCIL_FRONT_AND_BACK\r
+ };\r
+\r
+ using StencilFaceFlags = Flags<StencilFaceFlagBits, VkStencilFaceFlags>;\r
+\r
+ VULKAN_HPP_INLINE StencilFaceFlags operator|( StencilFaceFlagBits bit0, StencilFaceFlagBits bit1 )\r
+ {\r
+ return StencilFaceFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE StencilFaceFlags operator~( StencilFaceFlagBits bits )\r
+ {\r
+ return ~( StencilFaceFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<StencilFaceFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(StencilFaceFlagBits::eFront) | VkFlags(StencilFaceFlagBits::eBack) | VkFlags(StencilFaceFlagBits::eVkStencilFrontAndBack)\r
+ };\r
+ };\r
+\r
+ enum class DescriptorPoolCreateFlagBits\r
+ {\r
+ eFreeDescriptorSet = VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT,\r
+ eUpdateAfterBindEXT = VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT\r
+ };\r
+\r
+ using DescriptorPoolCreateFlags = Flags<DescriptorPoolCreateFlagBits, VkDescriptorPoolCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE DescriptorPoolCreateFlags operator|( DescriptorPoolCreateFlagBits bit0, DescriptorPoolCreateFlagBits bit1 )\r
+ {\r
+ return DescriptorPoolCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DescriptorPoolCreateFlags operator~( DescriptorPoolCreateFlagBits bits )\r
+ {\r
+ return ~( DescriptorPoolCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DescriptorPoolCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DescriptorPoolCreateFlagBits::eFreeDescriptorSet) | VkFlags(DescriptorPoolCreateFlagBits::eUpdateAfterBindEXT)\r
+ };\r
+ };\r
+\r
+ struct DescriptorPoolCreateInfo\r
+ {\r
+ DescriptorPoolCreateInfo( DescriptorPoolCreateFlags flags_ = DescriptorPoolCreateFlags(), uint32_t maxSets_ = 0, uint32_t poolSizeCount_ = 0, const DescriptorPoolSize* pPoolSizes_ = nullptr )\r
+ : flags( flags_ )\r
+ , maxSets( maxSets_ )\r
+ , poolSizeCount( poolSizeCount_ )\r
+ , pPoolSizes( pPoolSizes_ )\r
+ {\r
+ }\r
+\r
+ DescriptorPoolCreateInfo( VkDescriptorPoolCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorPoolCreateInfo ) );\r
+ }\r
+\r
+ DescriptorPoolCreateInfo& operator=( VkDescriptorPoolCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorPoolCreateInfo ) );\r
+ return *this;\r
+ }\r
+ DescriptorPoolCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorPoolCreateInfo& setFlags( DescriptorPoolCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorPoolCreateInfo& setMaxSets( uint32_t maxSets_ )\r
+ {\r
+ maxSets = maxSets_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorPoolCreateInfo& setPoolSizeCount( uint32_t poolSizeCount_ )\r
+ {\r
+ poolSizeCount = poolSizeCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorPoolCreateInfo& setPPoolSizes( const DescriptorPoolSize* pPoolSizes_ )\r
+ {\r
+ pPoolSizes = pPoolSizes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorPoolCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorPoolCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorPoolCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( maxSets == rhs.maxSets )\r
+ && ( poolSizeCount == rhs.poolSizeCount )\r
+ && ( pPoolSizes == rhs.pPoolSizes );\r
+ }\r
+\r
+ bool operator!=( DescriptorPoolCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorPoolCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DescriptorPoolCreateFlags flags;\r
+ uint32_t maxSets;\r
+ uint32_t poolSizeCount;\r
+ const DescriptorPoolSize* pPoolSizes;\r
+ };\r
+ static_assert( sizeof( DescriptorPoolCreateInfo ) == sizeof( VkDescriptorPoolCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class DependencyFlagBits\r
+ {\r
+ eByRegion = VK_DEPENDENCY_BY_REGION_BIT,\r
+ eDeviceGroup = VK_DEPENDENCY_DEVICE_GROUP_BIT,\r
+ eDeviceGroupKHR = VK_DEPENDENCY_DEVICE_GROUP_BIT,\r
+ eViewLocal = VK_DEPENDENCY_VIEW_LOCAL_BIT,\r
+ eViewLocalKHR = VK_DEPENDENCY_VIEW_LOCAL_BIT\r
+ };\r
+\r
+ using DependencyFlags = Flags<DependencyFlagBits, VkDependencyFlags>;\r
+\r
+ VULKAN_HPP_INLINE DependencyFlags operator|( DependencyFlagBits bit0, DependencyFlagBits bit1 )\r
+ {\r
+ return DependencyFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DependencyFlags operator~( DependencyFlagBits bits )\r
+ {\r
+ return ~( DependencyFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DependencyFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DependencyFlagBits::eByRegion) | VkFlags(DependencyFlagBits::eDeviceGroup) | VkFlags(DependencyFlagBits::eViewLocal)\r
+ };\r
+ };\r
+\r
+ struct SubpassDependency\r
+ {\r
+ SubpassDependency( uint32_t srcSubpass_ = 0, uint32_t dstSubpass_ = 0, PipelineStageFlags srcStageMask_ = PipelineStageFlags(), PipelineStageFlags dstStageMask_ = PipelineStageFlags(), AccessFlags srcAccessMask_ = AccessFlags(), AccessFlags dstAccessMask_ = AccessFlags(), DependencyFlags dependencyFlags_ = DependencyFlags() )\r
+ : srcSubpass( srcSubpass_ )\r
+ , dstSubpass( dstSubpass_ )\r
+ , srcStageMask( srcStageMask_ )\r
+ , dstStageMask( dstStageMask_ )\r
+ , srcAccessMask( srcAccessMask_ )\r
+ , dstAccessMask( dstAccessMask_ )\r
+ , dependencyFlags( dependencyFlags_ )\r
+ {\r
+ }\r
+\r
+ SubpassDependency( VkSubpassDependency const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubpassDependency ) );\r
+ }\r
+\r
+ SubpassDependency& operator=( VkSubpassDependency const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubpassDependency ) );\r
+ return *this;\r
+ }\r
+ SubpassDependency& setSrcSubpass( uint32_t srcSubpass_ )\r
+ {\r
+ srcSubpass = srcSubpass_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDependency& setDstSubpass( uint32_t dstSubpass_ )\r
+ {\r
+ dstSubpass = dstSubpass_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDependency& setSrcStageMask( PipelineStageFlags srcStageMask_ )\r
+ {\r
+ srcStageMask = srcStageMask_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDependency& setDstStageMask( PipelineStageFlags dstStageMask_ )\r
+ {\r
+ dstStageMask = dstStageMask_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDependency& setSrcAccessMask( AccessFlags srcAccessMask_ )\r
+ {\r
+ srcAccessMask = srcAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDependency& setDstAccessMask( AccessFlags dstAccessMask_ )\r
+ {\r
+ dstAccessMask = dstAccessMask_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDependency& setDependencyFlags( DependencyFlags dependencyFlags_ )\r
+ {\r
+ dependencyFlags = dependencyFlags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSubpassDependency&() const\r
+ {\r
+ return *reinterpret_cast<const VkSubpassDependency*>(this);\r
+ }\r
+\r
+ bool operator==( SubpassDependency const& rhs ) const\r
+ {\r
+ return ( srcSubpass == rhs.srcSubpass )\r
+ && ( dstSubpass == rhs.dstSubpass )\r
+ && ( srcStageMask == rhs.srcStageMask )\r
+ && ( dstStageMask == rhs.dstStageMask )\r
+ && ( srcAccessMask == rhs.srcAccessMask )\r
+ && ( dstAccessMask == rhs.dstAccessMask )\r
+ && ( dependencyFlags == rhs.dependencyFlags );\r
+ }\r
+\r
+ bool operator!=( SubpassDependency const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t srcSubpass;\r
+ uint32_t dstSubpass;\r
+ PipelineStageFlags srcStageMask;\r
+ PipelineStageFlags dstStageMask;\r
+ AccessFlags srcAccessMask;\r
+ AccessFlags dstAccessMask;\r
+ DependencyFlags dependencyFlags;\r
+ };\r
+ static_assert( sizeof( SubpassDependency ) == sizeof( VkSubpassDependency ), "struct and wrapper have different size!" );\r
+\r
+ enum class PresentModeKHR\r
+ {\r
+ eImmediate = VK_PRESENT_MODE_IMMEDIATE_KHR,\r
+ eMailbox = VK_PRESENT_MODE_MAILBOX_KHR,\r
+ eFifo = VK_PRESENT_MODE_FIFO_KHR,\r
+ eFifoRelaxed = VK_PRESENT_MODE_FIFO_RELAXED_KHR,\r
+ eSharedDemandRefresh = VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR,\r
+ eSharedContinuousRefresh = VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR\r
+ };\r
+\r
+ enum class ColorSpaceKHR\r
+ {\r
+ eSrgbNonlinear = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR,\r
+ eDisplayP3NonlinearEXT = VK_COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT,\r
+ eExtendedSrgbLinearEXT = VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT,\r
+ eDciP3LinearEXT = VK_COLOR_SPACE_DCI_P3_LINEAR_EXT,\r
+ eDciP3NonlinearEXT = VK_COLOR_SPACE_DCI_P3_NONLINEAR_EXT,\r
+ eBt709LinearEXT = VK_COLOR_SPACE_BT709_LINEAR_EXT,\r
+ eBt709NonlinearEXT = VK_COLOR_SPACE_BT709_NONLINEAR_EXT,\r
+ eBt2020LinearEXT = VK_COLOR_SPACE_BT2020_LINEAR_EXT,\r
+ eHdr10St2084EXT = VK_COLOR_SPACE_HDR10_ST2084_EXT,\r
+ eDolbyvisionEXT = VK_COLOR_SPACE_DOLBYVISION_EXT,\r
+ eHdr10HlgEXT = VK_COLOR_SPACE_HDR10_HLG_EXT,\r
+ eAdobergbLinearEXT = VK_COLOR_SPACE_ADOBERGB_LINEAR_EXT,\r
+ eAdobergbNonlinearEXT = VK_COLOR_SPACE_ADOBERGB_NONLINEAR_EXT,\r
+ ePassThroughEXT = VK_COLOR_SPACE_PASS_THROUGH_EXT,\r
+ eExtendedSrgbNonlinearEXT = VK_COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT\r
+ };\r
+\r
+ struct SurfaceFormatKHR\r
+ {\r
+ operator const VkSurfaceFormatKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSurfaceFormatKHR*>(this);\r
+ }\r
+\r
+ bool operator==( SurfaceFormatKHR const& rhs ) const\r
+ {\r
+ return ( format == rhs.format )\r
+ && ( colorSpace == rhs.colorSpace );\r
+ }\r
+\r
+ bool operator!=( SurfaceFormatKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ Format format;\r
+ ColorSpaceKHR colorSpace;\r
+ };\r
+ static_assert( sizeof( SurfaceFormatKHR ) == sizeof( VkSurfaceFormatKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct SurfaceFormat2KHR\r
+ {\r
+ operator const VkSurfaceFormat2KHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSurfaceFormat2KHR*>(this);\r
+ }\r
+\r
+ bool operator==( SurfaceFormat2KHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( surfaceFormat == rhs.surfaceFormat );\r
+ }\r
+\r
+ bool operator!=( SurfaceFormat2KHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSurfaceFormat2KHR;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ SurfaceFormatKHR surfaceFormat;\r
+ };\r
+ static_assert( sizeof( SurfaceFormat2KHR ) == sizeof( VkSurfaceFormat2KHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class DisplayPlaneAlphaFlagBitsKHR\r
+ {\r
+ eOpaque = VK_DISPLAY_PLANE_ALPHA_OPAQUE_BIT_KHR,\r
+ eGlobal = VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR,\r
+ ePerPixel = VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR,\r
+ ePerPixelPremultiplied = VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_PREMULTIPLIED_BIT_KHR\r
+ };\r
+\r
+ using DisplayPlaneAlphaFlagsKHR = Flags<DisplayPlaneAlphaFlagBitsKHR, VkDisplayPlaneAlphaFlagsKHR>;\r
+\r
+ VULKAN_HPP_INLINE DisplayPlaneAlphaFlagsKHR operator|( DisplayPlaneAlphaFlagBitsKHR bit0, DisplayPlaneAlphaFlagBitsKHR bit1 )\r
+ {\r
+ return DisplayPlaneAlphaFlagsKHR( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DisplayPlaneAlphaFlagsKHR operator~( DisplayPlaneAlphaFlagBitsKHR bits )\r
+ {\r
+ return ~( DisplayPlaneAlphaFlagsKHR( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DisplayPlaneAlphaFlagBitsKHR>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DisplayPlaneAlphaFlagBitsKHR::eOpaque) | VkFlags(DisplayPlaneAlphaFlagBitsKHR::eGlobal) | VkFlags(DisplayPlaneAlphaFlagBitsKHR::ePerPixel) | VkFlags(DisplayPlaneAlphaFlagBitsKHR::ePerPixelPremultiplied)\r
+ };\r
+ };\r
+\r
+ struct DisplayPlaneCapabilitiesKHR\r
+ {\r
+ operator const VkDisplayPlaneCapabilitiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayPlaneCapabilitiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayPlaneCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return ( supportedAlpha == rhs.supportedAlpha )\r
+ && ( minSrcPosition == rhs.minSrcPosition )\r
+ && ( maxSrcPosition == rhs.maxSrcPosition )\r
+ && ( minSrcExtent == rhs.minSrcExtent )\r
+ && ( maxSrcExtent == rhs.maxSrcExtent )\r
+ && ( minDstPosition == rhs.minDstPosition )\r
+ && ( maxDstPosition == rhs.maxDstPosition )\r
+ && ( minDstExtent == rhs.minDstExtent )\r
+ && ( maxDstExtent == rhs.maxDstExtent );\r
+ }\r
+\r
+ bool operator!=( DisplayPlaneCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DisplayPlaneAlphaFlagsKHR supportedAlpha;\r
+ Offset2D minSrcPosition;\r
+ Offset2D maxSrcPosition;\r
+ Extent2D minSrcExtent;\r
+ Extent2D maxSrcExtent;\r
+ Offset2D minDstPosition;\r
+ Offset2D maxDstPosition;\r
+ Extent2D minDstExtent;\r
+ Extent2D maxDstExtent;\r
+ };\r
+ static_assert( sizeof( DisplayPlaneCapabilitiesKHR ) == sizeof( VkDisplayPlaneCapabilitiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class CompositeAlphaFlagBitsKHR\r
+ {\r
+ eOpaque = VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR,\r
+ ePreMultiplied = VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR,\r
+ ePostMultiplied = VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR,\r
+ eInherit = VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR\r
+ };\r
+\r
+ using CompositeAlphaFlagsKHR = Flags<CompositeAlphaFlagBitsKHR, VkCompositeAlphaFlagsKHR>;\r
+\r
+ VULKAN_HPP_INLINE CompositeAlphaFlagsKHR operator|( CompositeAlphaFlagBitsKHR bit0, CompositeAlphaFlagBitsKHR bit1 )\r
+ {\r
+ return CompositeAlphaFlagsKHR( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE CompositeAlphaFlagsKHR operator~( CompositeAlphaFlagBitsKHR bits )\r
+ {\r
+ return ~( CompositeAlphaFlagsKHR( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<CompositeAlphaFlagBitsKHR>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(CompositeAlphaFlagBitsKHR::eOpaque) | VkFlags(CompositeAlphaFlagBitsKHR::ePreMultiplied) | VkFlags(CompositeAlphaFlagBitsKHR::ePostMultiplied) | VkFlags(CompositeAlphaFlagBitsKHR::eInherit)\r
+ };\r
+ };\r
+\r
+ enum class SurfaceTransformFlagBitsKHR\r
+ {\r
+ eIdentity = VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR,\r
+ eRotate90 = VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR,\r
+ eRotate180 = VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR,\r
+ eRotate270 = VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR,\r
+ eHorizontalMirror = VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR,\r
+ eHorizontalMirrorRotate90 = VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR,\r
+ eHorizontalMirrorRotate180 = VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR,\r
+ eHorizontalMirrorRotate270 = VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR,\r
+ eInherit = VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR\r
+ };\r
+\r
+ using SurfaceTransformFlagsKHR = Flags<SurfaceTransformFlagBitsKHR, VkSurfaceTransformFlagsKHR>;\r
+\r
+ VULKAN_HPP_INLINE SurfaceTransformFlagsKHR operator|( SurfaceTransformFlagBitsKHR bit0, SurfaceTransformFlagBitsKHR bit1 )\r
+ {\r
+ return SurfaceTransformFlagsKHR( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SurfaceTransformFlagsKHR operator~( SurfaceTransformFlagBitsKHR bits )\r
+ {\r
+ return ~( SurfaceTransformFlagsKHR( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SurfaceTransformFlagBitsKHR>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SurfaceTransformFlagBitsKHR::eIdentity) | VkFlags(SurfaceTransformFlagBitsKHR::eRotate90) | VkFlags(SurfaceTransformFlagBitsKHR::eRotate180) | VkFlags(SurfaceTransformFlagBitsKHR::eRotate270) | VkFlags(SurfaceTransformFlagBitsKHR::eHorizontalMirror) | VkFlags(SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate90) | VkFlags(SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate180) | VkFlags(SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate270) | VkFlags(SurfaceTransformFlagBitsKHR::eInherit)\r
+ };\r
+ };\r
+\r
+ struct DisplayPropertiesKHR\r
+ {\r
+ operator const VkDisplayPropertiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayPropertiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayPropertiesKHR const& rhs ) const\r
+ {\r
+ return ( display == rhs.display )\r
+ && ( displayName == rhs.displayName )\r
+ && ( physicalDimensions == rhs.physicalDimensions )\r
+ && ( physicalResolution == rhs.physicalResolution )\r
+ && ( supportedTransforms == rhs.supportedTransforms )\r
+ && ( planeReorderPossible == rhs.planeReorderPossible )\r
+ && ( persistentContent == rhs.persistentContent );\r
+ }\r
+\r
+ bool operator!=( DisplayPropertiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ DisplayKHR display;\r
+ const char* displayName;\r
+ Extent2D physicalDimensions;\r
+ Extent2D physicalResolution;\r
+ SurfaceTransformFlagsKHR supportedTransforms;\r
+ Bool32 planeReorderPossible;\r
+ Bool32 persistentContent;\r
+ };\r
+ static_assert( sizeof( DisplayPropertiesKHR ) == sizeof( VkDisplayPropertiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct DisplaySurfaceCreateInfoKHR\r
+ {\r
+ DisplaySurfaceCreateInfoKHR( DisplaySurfaceCreateFlagsKHR flags_ = DisplaySurfaceCreateFlagsKHR(), DisplayModeKHR displayMode_ = DisplayModeKHR(), uint32_t planeIndex_ = 0, uint32_t planeStackIndex_ = 0, SurfaceTransformFlagBitsKHR transform_ = SurfaceTransformFlagBitsKHR::eIdentity, float globalAlpha_ = 0, DisplayPlaneAlphaFlagBitsKHR alphaMode_ = DisplayPlaneAlphaFlagBitsKHR::eOpaque, Extent2D imageExtent_ = Extent2D() )\r
+ : flags( flags_ )\r
+ , displayMode( displayMode_ )\r
+ , planeIndex( planeIndex_ )\r
+ , planeStackIndex( planeStackIndex_ )\r
+ , transform( transform_ )\r
+ , globalAlpha( globalAlpha_ )\r
+ , alphaMode( alphaMode_ )\r
+ , imageExtent( imageExtent_ )\r
+ {\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR( VkDisplaySurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplaySurfaceCreateInfoKHR ) );\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& operator=( VkDisplaySurfaceCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplaySurfaceCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ DisplaySurfaceCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setFlags( DisplaySurfaceCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setDisplayMode( DisplayModeKHR displayMode_ )\r
+ {\r
+ displayMode = displayMode_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setPlaneIndex( uint32_t planeIndex_ )\r
+ {\r
+ planeIndex = planeIndex_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setPlaneStackIndex( uint32_t planeStackIndex_ )\r
+ {\r
+ planeStackIndex = planeStackIndex_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setTransform( SurfaceTransformFlagBitsKHR transform_ )\r
+ {\r
+ transform = transform_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setGlobalAlpha( float globalAlpha_ )\r
+ {\r
+ globalAlpha = globalAlpha_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setAlphaMode( DisplayPlaneAlphaFlagBitsKHR alphaMode_ )\r
+ {\r
+ alphaMode = alphaMode_;\r
+ return *this;\r
+ }\r
+\r
+ DisplaySurfaceCreateInfoKHR& setImageExtent( Extent2D imageExtent_ )\r
+ {\r
+ imageExtent = imageExtent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDisplaySurfaceCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplaySurfaceCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DisplaySurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( displayMode == rhs.displayMode )\r
+ && ( planeIndex == rhs.planeIndex )\r
+ && ( planeStackIndex == rhs.planeStackIndex )\r
+ && ( transform == rhs.transform )\r
+ && ( globalAlpha == rhs.globalAlpha )\r
+ && ( alphaMode == rhs.alphaMode )\r
+ && ( imageExtent == rhs.imageExtent );\r
+ }\r
+\r
+ bool operator!=( DisplaySurfaceCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDisplaySurfaceCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DisplaySurfaceCreateFlagsKHR flags;\r
+ DisplayModeKHR displayMode;\r
+ uint32_t planeIndex;\r
+ uint32_t planeStackIndex;\r
+ SurfaceTransformFlagBitsKHR transform;\r
+ float globalAlpha;\r
+ DisplayPlaneAlphaFlagBitsKHR alphaMode;\r
+ Extent2D imageExtent;\r
+ };\r
+ static_assert( sizeof( DisplaySurfaceCreateInfoKHR ) == sizeof( VkDisplaySurfaceCreateInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct SurfaceCapabilitiesKHR\r
+ {\r
+ operator const VkSurfaceCapabilitiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSurfaceCapabilitiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( SurfaceCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return ( minImageCount == rhs.minImageCount )\r
+ && ( maxImageCount == rhs.maxImageCount )\r
+ && ( currentExtent == rhs.currentExtent )\r
+ && ( minImageExtent == rhs.minImageExtent )\r
+ && ( maxImageExtent == rhs.maxImageExtent )\r
+ && ( maxImageArrayLayers == rhs.maxImageArrayLayers )\r
+ && ( supportedTransforms == rhs.supportedTransforms )\r
+ && ( currentTransform == rhs.currentTransform )\r
+ && ( supportedCompositeAlpha == rhs.supportedCompositeAlpha )\r
+ && ( supportedUsageFlags == rhs.supportedUsageFlags );\r
+ }\r
+\r
+ bool operator!=( SurfaceCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ uint32_t minImageCount;\r
+ uint32_t maxImageCount;\r
+ Extent2D currentExtent;\r
+ Extent2D minImageExtent;\r
+ Extent2D maxImageExtent;\r
+ uint32_t maxImageArrayLayers;\r
+ SurfaceTransformFlagsKHR supportedTransforms;\r
+ SurfaceTransformFlagBitsKHR currentTransform;\r
+ CompositeAlphaFlagsKHR supportedCompositeAlpha;\r
+ ImageUsageFlags supportedUsageFlags;\r
+ };\r
+ static_assert( sizeof( SurfaceCapabilitiesKHR ) == sizeof( VkSurfaceCapabilitiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct SurfaceCapabilities2KHR\r
+ {\r
+ operator const VkSurfaceCapabilities2KHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSurfaceCapabilities2KHR*>(this);\r
+ }\r
+\r
+ bool operator==( SurfaceCapabilities2KHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( surfaceCapabilities == rhs.surfaceCapabilities );\r
+ }\r
+\r
+ bool operator!=( SurfaceCapabilities2KHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSurfaceCapabilities2KHR;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ SurfaceCapabilitiesKHR surfaceCapabilities;\r
+ };\r
+ static_assert( sizeof( SurfaceCapabilities2KHR ) == sizeof( VkSurfaceCapabilities2KHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class DebugReportFlagBitsEXT\r
+ {\r
+ eInformation = VK_DEBUG_REPORT_INFORMATION_BIT_EXT,\r
+ eWarning = VK_DEBUG_REPORT_WARNING_BIT_EXT,\r
+ ePerformanceWarning = VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT,\r
+ eError = VK_DEBUG_REPORT_ERROR_BIT_EXT,\r
+ eDebug = VK_DEBUG_REPORT_DEBUG_BIT_EXT\r
+ };\r
+\r
+ using DebugReportFlagsEXT = Flags<DebugReportFlagBitsEXT, VkDebugReportFlagsEXT>;\r
+\r
+ VULKAN_HPP_INLINE DebugReportFlagsEXT operator|( DebugReportFlagBitsEXT bit0, DebugReportFlagBitsEXT bit1 )\r
+ {\r
+ return DebugReportFlagsEXT( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DebugReportFlagsEXT operator~( DebugReportFlagBitsEXT bits )\r
+ {\r
+ return ~( DebugReportFlagsEXT( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DebugReportFlagBitsEXT>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DebugReportFlagBitsEXT::eInformation) | VkFlags(DebugReportFlagBitsEXT::eWarning) | VkFlags(DebugReportFlagBitsEXT::ePerformanceWarning) | VkFlags(DebugReportFlagBitsEXT::eError) | VkFlags(DebugReportFlagBitsEXT::eDebug)\r
+ };\r
+ };\r
+\r
+ struct DebugReportCallbackCreateInfoEXT\r
+ {\r
+ DebugReportCallbackCreateInfoEXT( DebugReportFlagsEXT flags_ = DebugReportFlagsEXT(), PFN_vkDebugReportCallbackEXT pfnCallback_ = nullptr, void* pUserData_ = nullptr )\r
+ : flags( flags_ )\r
+ , pfnCallback( pfnCallback_ )\r
+ , pUserData( pUserData_ )\r
+ {\r
+ }\r
+\r
+ DebugReportCallbackCreateInfoEXT( VkDebugReportCallbackCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugReportCallbackCreateInfoEXT ) );\r
+ }\r
+\r
+ DebugReportCallbackCreateInfoEXT& operator=( VkDebugReportCallbackCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugReportCallbackCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugReportCallbackCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugReportCallbackCreateInfoEXT& setFlags( DebugReportFlagsEXT flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DebugReportCallbackCreateInfoEXT& setPfnCallback( PFN_vkDebugReportCallbackEXT pfnCallback_ )\r
+ {\r
+ pfnCallback = pfnCallback_;\r
+ return *this;\r
+ }\r
+\r
+ DebugReportCallbackCreateInfoEXT& setPUserData( void* pUserData_ )\r
+ {\r
+ pUserData = pUserData_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugReportCallbackCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugReportCallbackCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugReportCallbackCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( pfnCallback == rhs.pfnCallback )\r
+ && ( pUserData == rhs.pUserData );\r
+ }\r
+\r
+ bool operator!=( DebugReportCallbackCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugReportCallbackCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DebugReportFlagsEXT flags;\r
+ PFN_vkDebugReportCallbackEXT pfnCallback;\r
+ void* pUserData;\r
+ };\r
+ static_assert( sizeof( DebugReportCallbackCreateInfoEXT ) == sizeof( VkDebugReportCallbackCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class DebugReportObjectTypeEXT\r
+ {\r
+ eUnknown = VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT,\r
+ eInstance = VK_DEBUG_REPORT_OBJECT_TYPE_INSTANCE_EXT,\r
+ ePhysicalDevice = VK_DEBUG_REPORT_OBJECT_TYPE_PHYSICAL_DEVICE_EXT,\r
+ eDevice = VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_EXT,\r
+ eQueue = VK_DEBUG_REPORT_OBJECT_TYPE_QUEUE_EXT,\r
+ eSemaphore = VK_DEBUG_REPORT_OBJECT_TYPE_SEMAPHORE_EXT,\r
+ eCommandBuffer = VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_BUFFER_EXT,\r
+ eFence = VK_DEBUG_REPORT_OBJECT_TYPE_FENCE_EXT,\r
+ eDeviceMemory = VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMORY_EXT,\r
+ eBuffer = VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT,\r
+ eImage = VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT,\r
+ eEvent = VK_DEBUG_REPORT_OBJECT_TYPE_EVENT_EXT,\r
+ eQueryPool = VK_DEBUG_REPORT_OBJECT_TYPE_QUERY_POOL_EXT,\r
+ eBufferView = VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_VIEW_EXT,\r
+ eImageView = VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_VIEW_EXT,\r
+ eShaderModule = VK_DEBUG_REPORT_OBJECT_TYPE_SHADER_MODULE_EXT,\r
+ ePipelineCache = VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_CACHE_EXT,\r
+ ePipelineLayout = VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_LAYOUT_EXT,\r
+ eRenderPass = VK_DEBUG_REPORT_OBJECT_TYPE_RENDER_PASS_EXT,\r
+ ePipeline = VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT,\r
+ eDescriptorSetLayout = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT_EXT,\r
+ eSampler = VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_EXT,\r
+ eDescriptorPool = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_POOL_EXT,\r
+ eDescriptorSet = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_EXT,\r
+ eFramebuffer = VK_DEBUG_REPORT_OBJECT_TYPE_FRAMEBUFFER_EXT,\r
+ eCommandPool = VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_POOL_EXT,\r
+ eSurfaceKhr = VK_DEBUG_REPORT_OBJECT_TYPE_SURFACE_KHR_EXT,\r
+ eSwapchainKhr = VK_DEBUG_REPORT_OBJECT_TYPE_SWAPCHAIN_KHR_EXT,\r
+ eDebugReportCallbackExt = VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT,\r
+ eDisplayKhr = VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_KHR_EXT,\r
+ eDisplayModeKhr = VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_MODE_KHR_EXT,\r
+ eObjectTableNvx = VK_DEBUG_REPORT_OBJECT_TYPE_OBJECT_TABLE_NVX_EXT,\r
+ eIndirectCommandsLayoutNvx = VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT,\r
+ eValidationCacheExt = VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT,\r
+ eSamplerYcbcrConversion = VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT,\r
+ eSamplerYcbcrConversionKHR = VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT,\r
+ eDescriptorUpdateTemplate = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT,\r
+ eDescriptorUpdateTemplateKHR = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT\r
+ };\r
+\r
+ struct DebugMarkerObjectNameInfoEXT\r
+ {\r
+ DebugMarkerObjectNameInfoEXT( DebugReportObjectTypeEXT objectType_ = DebugReportObjectTypeEXT::eUnknown, uint64_t object_ = 0, const char* pObjectName_ = nullptr )\r
+ : objectType( objectType_ )\r
+ , object( object_ )\r
+ , pObjectName( pObjectName_ )\r
+ {\r
+ }\r
+\r
+ DebugMarkerObjectNameInfoEXT( VkDebugMarkerObjectNameInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugMarkerObjectNameInfoEXT ) );\r
+ }\r
+\r
+ DebugMarkerObjectNameInfoEXT& operator=( VkDebugMarkerObjectNameInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugMarkerObjectNameInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugMarkerObjectNameInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectNameInfoEXT& setObjectType( DebugReportObjectTypeEXT objectType_ )\r
+ {\r
+ objectType = objectType_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectNameInfoEXT& setObject( uint64_t object_ )\r
+ {\r
+ object = object_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectNameInfoEXT& setPObjectName( const char* pObjectName_ )\r
+ {\r
+ pObjectName = pObjectName_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugMarkerObjectNameInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugMarkerObjectNameInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugMarkerObjectNameInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectType == rhs.objectType )\r
+ && ( object == rhs.object )\r
+ && ( pObjectName == rhs.pObjectName );\r
+ }\r
+\r
+ bool operator!=( DebugMarkerObjectNameInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugMarkerObjectNameInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DebugReportObjectTypeEXT objectType;\r
+ uint64_t object;\r
+ const char* pObjectName;\r
+ };\r
+ static_assert( sizeof( DebugMarkerObjectNameInfoEXT ) == sizeof( VkDebugMarkerObjectNameInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ struct DebugMarkerObjectTagInfoEXT\r
+ {\r
+ DebugMarkerObjectTagInfoEXT( DebugReportObjectTypeEXT objectType_ = DebugReportObjectTypeEXT::eUnknown, uint64_t object_ = 0, uint64_t tagName_ = 0, size_t tagSize_ = 0, const void* pTag_ = nullptr )\r
+ : objectType( objectType_ )\r
+ , object( object_ )\r
+ , tagName( tagName_ )\r
+ , tagSize( tagSize_ )\r
+ , pTag( pTag_ )\r
+ {\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT( VkDebugMarkerObjectTagInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugMarkerObjectTagInfoEXT ) );\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT& operator=( VkDebugMarkerObjectTagInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugMarkerObjectTagInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugMarkerObjectTagInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT& setObjectType( DebugReportObjectTypeEXT objectType_ )\r
+ {\r
+ objectType = objectType_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT& setObject( uint64_t object_ )\r
+ {\r
+ object = object_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT& setTagName( uint64_t tagName_ )\r
+ {\r
+ tagName = tagName_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT& setTagSize( size_t tagSize_ )\r
+ {\r
+ tagSize = tagSize_;\r
+ return *this;\r
+ }\r
+\r
+ DebugMarkerObjectTagInfoEXT& setPTag( const void* pTag_ )\r
+ {\r
+ pTag = pTag_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugMarkerObjectTagInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugMarkerObjectTagInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugMarkerObjectTagInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectType == rhs.objectType )\r
+ && ( object == rhs.object )\r
+ && ( tagName == rhs.tagName )\r
+ && ( tagSize == rhs.tagSize )\r
+ && ( pTag == rhs.pTag );\r
+ }\r
+\r
+ bool operator!=( DebugMarkerObjectTagInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugMarkerObjectTagInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DebugReportObjectTypeEXT objectType;\r
+ uint64_t object;\r
+ uint64_t tagName;\r
+ size_t tagSize;\r
+ const void* pTag;\r
+ };\r
+ static_assert( sizeof( DebugMarkerObjectTagInfoEXT ) == sizeof( VkDebugMarkerObjectTagInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class RasterizationOrderAMD\r
+ {\r
+ eStrict = VK_RASTERIZATION_ORDER_STRICT_AMD,\r
+ eRelaxed = VK_RASTERIZATION_ORDER_RELAXED_AMD\r
+ };\r
+\r
+ struct PipelineRasterizationStateRasterizationOrderAMD\r
+ {\r
+ PipelineRasterizationStateRasterizationOrderAMD( RasterizationOrderAMD rasterizationOrder_ = RasterizationOrderAMD::eStrict )\r
+ : rasterizationOrder( rasterizationOrder_ )\r
+ {\r
+ }\r
+\r
+ PipelineRasterizationStateRasterizationOrderAMD( VkPipelineRasterizationStateRasterizationOrderAMD const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineRasterizationStateRasterizationOrderAMD ) );\r
+ }\r
+\r
+ PipelineRasterizationStateRasterizationOrderAMD& operator=( VkPipelineRasterizationStateRasterizationOrderAMD const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineRasterizationStateRasterizationOrderAMD ) );\r
+ return *this;\r
+ }\r
+ PipelineRasterizationStateRasterizationOrderAMD& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationStateRasterizationOrderAMD& setRasterizationOrder( RasterizationOrderAMD rasterizationOrder_ )\r
+ {\r
+ rasterizationOrder = rasterizationOrder_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineRasterizationStateRasterizationOrderAMD&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineRasterizationStateRasterizationOrderAMD*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineRasterizationStateRasterizationOrderAMD const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( rasterizationOrder == rhs.rasterizationOrder );\r
+ }\r
+\r
+ bool operator!=( PipelineRasterizationStateRasterizationOrderAMD const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineRasterizationStateRasterizationOrderAMD;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ RasterizationOrderAMD rasterizationOrder;\r
+ };\r
+ static_assert( sizeof( PipelineRasterizationStateRasterizationOrderAMD ) == sizeof( VkPipelineRasterizationStateRasterizationOrderAMD ), "struct and wrapper have different size!" );\r
+\r
+ enum class ExternalMemoryHandleTypeFlagBitsNV\r
+ {\r
+ eOpaqueWin32 = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_NV,\r
+ eOpaqueWin32Kmt = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_NV,\r
+ eD3D11Image = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_BIT_NV,\r
+ eD3D11ImageKmt = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_KMT_BIT_NV\r
+ };\r
+\r
+ using ExternalMemoryHandleTypeFlagsNV = Flags<ExternalMemoryHandleTypeFlagBitsNV, VkExternalMemoryHandleTypeFlagsNV>;\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryHandleTypeFlagsNV operator|( ExternalMemoryHandleTypeFlagBitsNV bit0, ExternalMemoryHandleTypeFlagBitsNV bit1 )\r
+ {\r
+ return ExternalMemoryHandleTypeFlagsNV( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryHandleTypeFlagsNV operator~( ExternalMemoryHandleTypeFlagBitsNV bits )\r
+ {\r
+ return ~( ExternalMemoryHandleTypeFlagsNV( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalMemoryHandleTypeFlagBitsNV>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalMemoryHandleTypeFlagBitsNV::eOpaqueWin32) | VkFlags(ExternalMemoryHandleTypeFlagBitsNV::eOpaqueWin32Kmt) | VkFlags(ExternalMemoryHandleTypeFlagBitsNV::eD3D11Image) | VkFlags(ExternalMemoryHandleTypeFlagBitsNV::eD3D11ImageKmt)\r
+ };\r
+ };\r
+\r
+ struct ExternalMemoryImageCreateInfoNV\r
+ {\r
+ ExternalMemoryImageCreateInfoNV( ExternalMemoryHandleTypeFlagsNV handleTypes_ = ExternalMemoryHandleTypeFlagsNV() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExternalMemoryImageCreateInfoNV( VkExternalMemoryImageCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalMemoryImageCreateInfoNV ) );\r
+ }\r
+\r
+ ExternalMemoryImageCreateInfoNV& operator=( VkExternalMemoryImageCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalMemoryImageCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ ExternalMemoryImageCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExternalMemoryImageCreateInfoNV& setHandleTypes( ExternalMemoryHandleTypeFlagsNV handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExternalMemoryImageCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalMemoryImageCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalMemoryImageCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExternalMemoryImageCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalMemoryImageCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagsNV handleTypes;\r
+ };\r
+ static_assert( sizeof( ExternalMemoryImageCreateInfoNV ) == sizeof( VkExternalMemoryImageCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ struct ExportMemoryAllocateInfoNV\r
+ {\r
+ ExportMemoryAllocateInfoNV( ExternalMemoryHandleTypeFlagsNV handleTypes_ = ExternalMemoryHandleTypeFlagsNV() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExportMemoryAllocateInfoNV( VkExportMemoryAllocateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryAllocateInfoNV ) );\r
+ }\r
+\r
+ ExportMemoryAllocateInfoNV& operator=( VkExportMemoryAllocateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryAllocateInfoNV ) );\r
+ return *this;\r
+ }\r
+ ExportMemoryAllocateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryAllocateInfoNV& setHandleTypes( ExternalMemoryHandleTypeFlagsNV handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportMemoryAllocateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportMemoryAllocateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( ExportMemoryAllocateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExportMemoryAllocateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportMemoryAllocateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagsNV handleTypes;\r
+ };\r
+ static_assert( sizeof( ExportMemoryAllocateInfoNV ) == sizeof( VkExportMemoryAllocateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ struct ImportMemoryWin32HandleInfoNV\r
+ {\r
+ ImportMemoryWin32HandleInfoNV( ExternalMemoryHandleTypeFlagsNV handleType_ = ExternalMemoryHandleTypeFlagsNV(), HANDLE handle_ = 0 )\r
+ : handleType( handleType_ )\r
+ , handle( handle_ )\r
+ {\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoNV( VkImportMemoryWin32HandleInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryWin32HandleInfoNV ) );\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoNV& operator=( VkImportMemoryWin32HandleInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryWin32HandleInfoNV ) );\r
+ return *this;\r
+ }\r
+ ImportMemoryWin32HandleInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoNV& setHandleType( ExternalMemoryHandleTypeFlagsNV handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoNV& setHandle( HANDLE handle_ )\r
+ {\r
+ handle = handle_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportMemoryWin32HandleInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportMemoryWin32HandleInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( ImportMemoryWin32HandleInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType )\r
+ && ( handle == rhs.handle );\r
+ }\r
+\r
+ bool operator!=( ImportMemoryWin32HandleInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportMemoryWin32HandleInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagsNV handleType;\r
+ HANDLE handle;\r
+ };\r
+ static_assert( sizeof( ImportMemoryWin32HandleInfoNV ) == sizeof( VkImportMemoryWin32HandleInfoNV ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+\r
+ enum class ExternalMemoryFeatureFlagBitsNV\r
+ {\r
+ eDedicatedOnly = VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_NV,\r
+ eExportable = VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_NV,\r
+ eImportable = VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_NV\r
+ };\r
+\r
+ using ExternalMemoryFeatureFlagsNV = Flags<ExternalMemoryFeatureFlagBitsNV, VkExternalMemoryFeatureFlagsNV>;\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryFeatureFlagsNV operator|( ExternalMemoryFeatureFlagBitsNV bit0, ExternalMemoryFeatureFlagBitsNV bit1 )\r
+ {\r
+ return ExternalMemoryFeatureFlagsNV( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryFeatureFlagsNV operator~( ExternalMemoryFeatureFlagBitsNV bits )\r
+ {\r
+ return ~( ExternalMemoryFeatureFlagsNV( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalMemoryFeatureFlagBitsNV>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalMemoryFeatureFlagBitsNV::eDedicatedOnly) | VkFlags(ExternalMemoryFeatureFlagBitsNV::eExportable) | VkFlags(ExternalMemoryFeatureFlagBitsNV::eImportable)\r
+ };\r
+ };\r
+\r
+ struct ExternalImageFormatPropertiesNV\r
+ {\r
+ operator const VkExternalImageFormatPropertiesNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalImageFormatPropertiesNV*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalImageFormatPropertiesNV const& rhs ) const\r
+ {\r
+ return ( imageFormatProperties == rhs.imageFormatProperties )\r
+ && ( externalMemoryFeatures == rhs.externalMemoryFeatures )\r
+ && ( exportFromImportedHandleTypes == rhs.exportFromImportedHandleTypes )\r
+ && ( compatibleHandleTypes == rhs.compatibleHandleTypes );\r
+ }\r
+\r
+ bool operator!=( ExternalImageFormatPropertiesNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ImageFormatProperties imageFormatProperties;\r
+ ExternalMemoryFeatureFlagsNV externalMemoryFeatures;\r
+ ExternalMemoryHandleTypeFlagsNV exportFromImportedHandleTypes;\r
+ ExternalMemoryHandleTypeFlagsNV compatibleHandleTypes;\r
+ };\r
+ static_assert( sizeof( ExternalImageFormatPropertiesNV ) == sizeof( VkExternalImageFormatPropertiesNV ), "struct and wrapper have different size!" );\r
+\r
+ enum class ValidationCheckEXT\r
+ {\r
+ eAll = VK_VALIDATION_CHECK_ALL_EXT,\r
+ eShaders = VK_VALIDATION_CHECK_SHADERS_EXT\r
+ };\r
+\r
+ struct ValidationFlagsEXT\r
+ {\r
+ ValidationFlagsEXT( uint32_t disabledValidationCheckCount_ = 0, ValidationCheckEXT* pDisabledValidationChecks_ = nullptr )\r
+ : disabledValidationCheckCount( disabledValidationCheckCount_ )\r
+ , pDisabledValidationChecks( pDisabledValidationChecks_ )\r
+ {\r
+ }\r
+\r
+ ValidationFlagsEXT( VkValidationFlagsEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ValidationFlagsEXT ) );\r
+ }\r
+\r
+ ValidationFlagsEXT& operator=( VkValidationFlagsEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ValidationFlagsEXT ) );\r
+ return *this;\r
+ }\r
+ ValidationFlagsEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ValidationFlagsEXT& setDisabledValidationCheckCount( uint32_t disabledValidationCheckCount_ )\r
+ {\r
+ disabledValidationCheckCount = disabledValidationCheckCount_;\r
+ return *this;\r
+ }\r
+\r
+ ValidationFlagsEXT& setPDisabledValidationChecks( ValidationCheckEXT* pDisabledValidationChecks_ )\r
+ {\r
+ pDisabledValidationChecks = pDisabledValidationChecks_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkValidationFlagsEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkValidationFlagsEXT*>(this);\r
+ }\r
+\r
+ bool operator==( ValidationFlagsEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( disabledValidationCheckCount == rhs.disabledValidationCheckCount )\r
+ && ( pDisabledValidationChecks == rhs.pDisabledValidationChecks );\r
+ }\r
+\r
+ bool operator!=( ValidationFlagsEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eValidationFlagsEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t disabledValidationCheckCount;\r
+ ValidationCheckEXT* pDisabledValidationChecks;\r
+ };\r
+ static_assert( sizeof( ValidationFlagsEXT ) == sizeof( VkValidationFlagsEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class SubgroupFeatureFlagBits\r
+ {\r
+ eBasic = VK_SUBGROUP_FEATURE_BASIC_BIT,\r
+ eVote = VK_SUBGROUP_FEATURE_VOTE_BIT,\r
+ eArithmetic = VK_SUBGROUP_FEATURE_ARITHMETIC_BIT,\r
+ eBallot = VK_SUBGROUP_FEATURE_BALLOT_BIT,\r
+ eShuffle = VK_SUBGROUP_FEATURE_SHUFFLE_BIT,\r
+ eShuffleRelative = VK_SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT,\r
+ eClustered = VK_SUBGROUP_FEATURE_CLUSTERED_BIT,\r
+ eQuad = VK_SUBGROUP_FEATURE_QUAD_BIT,\r
+ ePartitionedNV = VK_SUBGROUP_FEATURE_PARTITIONED_BIT_NV\r
+ };\r
+\r
+ using SubgroupFeatureFlags = Flags<SubgroupFeatureFlagBits, VkSubgroupFeatureFlags>;\r
+\r
+ VULKAN_HPP_INLINE SubgroupFeatureFlags operator|( SubgroupFeatureFlagBits bit0, SubgroupFeatureFlagBits bit1 )\r
+ {\r
+ return SubgroupFeatureFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SubgroupFeatureFlags operator~( SubgroupFeatureFlagBits bits )\r
+ {\r
+ return ~( SubgroupFeatureFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SubgroupFeatureFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SubgroupFeatureFlagBits::eBasic) | VkFlags(SubgroupFeatureFlagBits::eVote) | VkFlags(SubgroupFeatureFlagBits::eArithmetic) | VkFlags(SubgroupFeatureFlagBits::eBallot) | VkFlags(SubgroupFeatureFlagBits::eShuffle) | VkFlags(SubgroupFeatureFlagBits::eShuffleRelative) | VkFlags(SubgroupFeatureFlagBits::eClustered) | VkFlags(SubgroupFeatureFlagBits::eQuad) | VkFlags(SubgroupFeatureFlagBits::ePartitionedNV)\r
+ };\r
+ };\r
+\r
+ struct PhysicalDeviceSubgroupProperties\r
+ {\r
+ operator const VkPhysicalDeviceSubgroupProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceSubgroupProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceSubgroupProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( subgroupSize == rhs.subgroupSize )\r
+ && ( supportedStages == rhs.supportedStages )\r
+ && ( supportedOperations == rhs.supportedOperations )\r
+ && ( quadOperationsInAllStages == rhs.quadOperationsInAllStages );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceSubgroupProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceSubgroupProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t subgroupSize;\r
+ ShaderStageFlags supportedStages;\r
+ SubgroupFeatureFlags supportedOperations;\r
+ Bool32 quadOperationsInAllStages;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceSubgroupProperties ) == sizeof( VkPhysicalDeviceSubgroupProperties ), "struct and wrapper have different size!" );\r
+\r
+ enum class IndirectCommandsLayoutUsageFlagBitsNVX\r
+ {\r
+ eUnorderedSequences = VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX,\r
+ eSparseSequences = VK_INDIRECT_COMMANDS_LAYOUT_USAGE_SPARSE_SEQUENCES_BIT_NVX,\r
+ eEmptyExecutions = VK_INDIRECT_COMMANDS_LAYOUT_USAGE_EMPTY_EXECUTIONS_BIT_NVX,\r
+ eIndexedSequences = VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX\r
+ };\r
+\r
+ using IndirectCommandsLayoutUsageFlagsNVX = Flags<IndirectCommandsLayoutUsageFlagBitsNVX, VkIndirectCommandsLayoutUsageFlagsNVX>;\r
+\r
+ VULKAN_HPP_INLINE IndirectCommandsLayoutUsageFlagsNVX operator|( IndirectCommandsLayoutUsageFlagBitsNVX bit0, IndirectCommandsLayoutUsageFlagBitsNVX bit1 )\r
+ {\r
+ return IndirectCommandsLayoutUsageFlagsNVX( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE IndirectCommandsLayoutUsageFlagsNVX operator~( IndirectCommandsLayoutUsageFlagBitsNVX bits )\r
+ {\r
+ return ~( IndirectCommandsLayoutUsageFlagsNVX( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<IndirectCommandsLayoutUsageFlagBitsNVX>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(IndirectCommandsLayoutUsageFlagBitsNVX::eUnorderedSequences) | VkFlags(IndirectCommandsLayoutUsageFlagBitsNVX::eSparseSequences) | VkFlags(IndirectCommandsLayoutUsageFlagBitsNVX::eEmptyExecutions) | VkFlags(IndirectCommandsLayoutUsageFlagBitsNVX::eIndexedSequences)\r
+ };\r
+ };\r
+\r
+ enum class ObjectEntryUsageFlagBitsNVX\r
+ {\r
+ eGraphics = VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX,\r
+ eCompute = VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX\r
+ };\r
+\r
+ using ObjectEntryUsageFlagsNVX = Flags<ObjectEntryUsageFlagBitsNVX, VkObjectEntryUsageFlagsNVX>;\r
+\r
+ VULKAN_HPP_INLINE ObjectEntryUsageFlagsNVX operator|( ObjectEntryUsageFlagBitsNVX bit0, ObjectEntryUsageFlagBitsNVX bit1 )\r
+ {\r
+ return ObjectEntryUsageFlagsNVX( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ObjectEntryUsageFlagsNVX operator~( ObjectEntryUsageFlagBitsNVX bits )\r
+ {\r
+ return ~( ObjectEntryUsageFlagsNVX( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ObjectEntryUsageFlagBitsNVX>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ObjectEntryUsageFlagBitsNVX::eGraphics) | VkFlags(ObjectEntryUsageFlagBitsNVX::eCompute)\r
+ };\r
+ };\r
+\r
+ enum class IndirectCommandsTokenTypeNVX\r
+ {\r
+ ePipeline = VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX,\r
+ eDescriptorSet = VK_INDIRECT_COMMANDS_TOKEN_TYPE_DESCRIPTOR_SET_NVX,\r
+ eIndexBuffer = VK_INDIRECT_COMMANDS_TOKEN_TYPE_INDEX_BUFFER_NVX,\r
+ eVertexBuffer = VK_INDIRECT_COMMANDS_TOKEN_TYPE_VERTEX_BUFFER_NVX,\r
+ ePushConstant = VK_INDIRECT_COMMANDS_TOKEN_TYPE_PUSH_CONSTANT_NVX,\r
+ eDrawIndexed = VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED_NVX,\r
+ eDraw = VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX,\r
+ eDispatch = VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX\r
+ };\r
+\r
+ struct IndirectCommandsTokenNVX\r
+ {\r
+ IndirectCommandsTokenNVX( IndirectCommandsTokenTypeNVX tokenType_ = IndirectCommandsTokenTypeNVX::ePipeline, Buffer buffer_ = Buffer(), DeviceSize offset_ = 0 )\r
+ : tokenType( tokenType_ )\r
+ , buffer( buffer_ )\r
+ , offset( offset_ )\r
+ {\r
+ }\r
+\r
+ IndirectCommandsTokenNVX( VkIndirectCommandsTokenNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IndirectCommandsTokenNVX ) );\r
+ }\r
+\r
+ IndirectCommandsTokenNVX& operator=( VkIndirectCommandsTokenNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IndirectCommandsTokenNVX ) );\r
+ return *this;\r
+ }\r
+ IndirectCommandsTokenNVX& setTokenType( IndirectCommandsTokenTypeNVX tokenType_ )\r
+ {\r
+ tokenType = tokenType_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsTokenNVX& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsTokenNVX& setOffset( DeviceSize offset_ )\r
+ {\r
+ offset = offset_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkIndirectCommandsTokenNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkIndirectCommandsTokenNVX*>(this);\r
+ }\r
+\r
+ bool operator==( IndirectCommandsTokenNVX const& rhs ) const\r
+ {\r
+ return ( tokenType == rhs.tokenType )\r
+ && ( buffer == rhs.buffer )\r
+ && ( offset == rhs.offset );\r
+ }\r
+\r
+ bool operator!=( IndirectCommandsTokenNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ IndirectCommandsTokenTypeNVX tokenType;\r
+ Buffer buffer;\r
+ DeviceSize offset;\r
+ };\r
+ static_assert( sizeof( IndirectCommandsTokenNVX ) == sizeof( VkIndirectCommandsTokenNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct IndirectCommandsLayoutTokenNVX\r
+ {\r
+ IndirectCommandsLayoutTokenNVX( IndirectCommandsTokenTypeNVX tokenType_ = IndirectCommandsTokenTypeNVX::ePipeline, uint32_t bindingUnit_ = 0, uint32_t dynamicCount_ = 0, uint32_t divisor_ = 0 )\r
+ : tokenType( tokenType_ )\r
+ , bindingUnit( bindingUnit_ )\r
+ , dynamicCount( dynamicCount_ )\r
+ , divisor( divisor_ )\r
+ {\r
+ }\r
+\r
+ IndirectCommandsLayoutTokenNVX( VkIndirectCommandsLayoutTokenNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IndirectCommandsLayoutTokenNVX ) );\r
+ }\r
+\r
+ IndirectCommandsLayoutTokenNVX& operator=( VkIndirectCommandsLayoutTokenNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IndirectCommandsLayoutTokenNVX ) );\r
+ return *this;\r
+ }\r
+ IndirectCommandsLayoutTokenNVX& setTokenType( IndirectCommandsTokenTypeNVX tokenType_ )\r
+ {\r
+ tokenType = tokenType_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutTokenNVX& setBindingUnit( uint32_t bindingUnit_ )\r
+ {\r
+ bindingUnit = bindingUnit_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutTokenNVX& setDynamicCount( uint32_t dynamicCount_ )\r
+ {\r
+ dynamicCount = dynamicCount_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutTokenNVX& setDivisor( uint32_t divisor_ )\r
+ {\r
+ divisor = divisor_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkIndirectCommandsLayoutTokenNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkIndirectCommandsLayoutTokenNVX*>(this);\r
+ }\r
+\r
+ bool operator==( IndirectCommandsLayoutTokenNVX const& rhs ) const\r
+ {\r
+ return ( tokenType == rhs.tokenType )\r
+ && ( bindingUnit == rhs.bindingUnit )\r
+ && ( dynamicCount == rhs.dynamicCount )\r
+ && ( divisor == rhs.divisor );\r
+ }\r
+\r
+ bool operator!=( IndirectCommandsLayoutTokenNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ IndirectCommandsTokenTypeNVX tokenType;\r
+ uint32_t bindingUnit;\r
+ uint32_t dynamicCount;\r
+ uint32_t divisor;\r
+ };\r
+ static_assert( sizeof( IndirectCommandsLayoutTokenNVX ) == sizeof( VkIndirectCommandsLayoutTokenNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct IndirectCommandsLayoutCreateInfoNVX\r
+ {\r
+ IndirectCommandsLayoutCreateInfoNVX( PipelineBindPoint pipelineBindPoint_ = PipelineBindPoint::eGraphics, IndirectCommandsLayoutUsageFlagsNVX flags_ = IndirectCommandsLayoutUsageFlagsNVX(), uint32_t tokenCount_ = 0, const IndirectCommandsLayoutTokenNVX* pTokens_ = nullptr )\r
+ : pipelineBindPoint( pipelineBindPoint_ )\r
+ , flags( flags_ )\r
+ , tokenCount( tokenCount_ )\r
+ , pTokens( pTokens_ )\r
+ {\r
+ }\r
+\r
+ IndirectCommandsLayoutCreateInfoNVX( VkIndirectCommandsLayoutCreateInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IndirectCommandsLayoutCreateInfoNVX ) );\r
+ }\r
+\r
+ IndirectCommandsLayoutCreateInfoNVX& operator=( VkIndirectCommandsLayoutCreateInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( IndirectCommandsLayoutCreateInfoNVX ) );\r
+ return *this;\r
+ }\r
+ IndirectCommandsLayoutCreateInfoNVX& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutCreateInfoNVX& setPipelineBindPoint( PipelineBindPoint pipelineBindPoint_ )\r
+ {\r
+ pipelineBindPoint = pipelineBindPoint_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutCreateInfoNVX& setFlags( IndirectCommandsLayoutUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutCreateInfoNVX& setTokenCount( uint32_t tokenCount_ )\r
+ {\r
+ tokenCount = tokenCount_;\r
+ return *this;\r
+ }\r
+\r
+ IndirectCommandsLayoutCreateInfoNVX& setPTokens( const IndirectCommandsLayoutTokenNVX* pTokens_ )\r
+ {\r
+ pTokens = pTokens_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkIndirectCommandsLayoutCreateInfoNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkIndirectCommandsLayoutCreateInfoNVX*>(this);\r
+ }\r
+\r
+ bool operator==( IndirectCommandsLayoutCreateInfoNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pipelineBindPoint == rhs.pipelineBindPoint )\r
+ && ( flags == rhs.flags )\r
+ && ( tokenCount == rhs.tokenCount )\r
+ && ( pTokens == rhs.pTokens );\r
+ }\r
+\r
+ bool operator!=( IndirectCommandsLayoutCreateInfoNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eIndirectCommandsLayoutCreateInfoNVX;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineBindPoint pipelineBindPoint;\r
+ IndirectCommandsLayoutUsageFlagsNVX flags;\r
+ uint32_t tokenCount;\r
+ const IndirectCommandsLayoutTokenNVX* pTokens;\r
+ };\r
+ static_assert( sizeof( IndirectCommandsLayoutCreateInfoNVX ) == sizeof( VkIndirectCommandsLayoutCreateInfoNVX ), "struct and wrapper have different size!" );\r
+\r
+ enum class ObjectEntryTypeNVX\r
+ {\r
+ eDescriptorSet = VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX,\r
+ ePipeline = VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX,\r
+ eIndexBuffer = VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX,\r
+ eVertexBuffer = VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX,\r
+ ePushConstant = VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX\r
+ };\r
+\r
+ struct ObjectTableCreateInfoNVX\r
+ {\r
+ ObjectTableCreateInfoNVX( uint32_t objectCount_ = 0, const ObjectEntryTypeNVX* pObjectEntryTypes_ = nullptr, const uint32_t* pObjectEntryCounts_ = nullptr, const ObjectEntryUsageFlagsNVX* pObjectEntryUsageFlags_ = nullptr, uint32_t maxUniformBuffersPerDescriptor_ = 0, uint32_t maxStorageBuffersPerDescriptor_ = 0, uint32_t maxStorageImagesPerDescriptor_ = 0, uint32_t maxSampledImagesPerDescriptor_ = 0, uint32_t maxPipelineLayouts_ = 0 )\r
+ : objectCount( objectCount_ )\r
+ , pObjectEntryTypes( pObjectEntryTypes_ )\r
+ , pObjectEntryCounts( pObjectEntryCounts_ )\r
+ , pObjectEntryUsageFlags( pObjectEntryUsageFlags_ )\r
+ , maxUniformBuffersPerDescriptor( maxUniformBuffersPerDescriptor_ )\r
+ , maxStorageBuffersPerDescriptor( maxStorageBuffersPerDescriptor_ )\r
+ , maxStorageImagesPerDescriptor( maxStorageImagesPerDescriptor_ )\r
+ , maxSampledImagesPerDescriptor( maxSampledImagesPerDescriptor_ )\r
+ , maxPipelineLayouts( maxPipelineLayouts_ )\r
+ {\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX( VkObjectTableCreateInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableCreateInfoNVX ) );\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& operator=( VkObjectTableCreateInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableCreateInfoNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTableCreateInfoNVX& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setObjectCount( uint32_t objectCount_ )\r
+ {\r
+ objectCount = objectCount_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setPObjectEntryTypes( const ObjectEntryTypeNVX* pObjectEntryTypes_ )\r
+ {\r
+ pObjectEntryTypes = pObjectEntryTypes_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setPObjectEntryCounts( const uint32_t* pObjectEntryCounts_ )\r
+ {\r
+ pObjectEntryCounts = pObjectEntryCounts_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setPObjectEntryUsageFlags( const ObjectEntryUsageFlagsNVX* pObjectEntryUsageFlags_ )\r
+ {\r
+ pObjectEntryUsageFlags = pObjectEntryUsageFlags_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setMaxUniformBuffersPerDescriptor( uint32_t maxUniformBuffersPerDescriptor_ )\r
+ {\r
+ maxUniformBuffersPerDescriptor = maxUniformBuffersPerDescriptor_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setMaxStorageBuffersPerDescriptor( uint32_t maxStorageBuffersPerDescriptor_ )\r
+ {\r
+ maxStorageBuffersPerDescriptor = maxStorageBuffersPerDescriptor_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setMaxStorageImagesPerDescriptor( uint32_t maxStorageImagesPerDescriptor_ )\r
+ {\r
+ maxStorageImagesPerDescriptor = maxStorageImagesPerDescriptor_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setMaxSampledImagesPerDescriptor( uint32_t maxSampledImagesPerDescriptor_ )\r
+ {\r
+ maxSampledImagesPerDescriptor = maxSampledImagesPerDescriptor_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableCreateInfoNVX& setMaxPipelineLayouts( uint32_t maxPipelineLayouts_ )\r
+ {\r
+ maxPipelineLayouts = maxPipelineLayouts_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTableCreateInfoNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTableCreateInfoNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTableCreateInfoNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectCount == rhs.objectCount )\r
+ && ( pObjectEntryTypes == rhs.pObjectEntryTypes )\r
+ && ( pObjectEntryCounts == rhs.pObjectEntryCounts )\r
+ && ( pObjectEntryUsageFlags == rhs.pObjectEntryUsageFlags )\r
+ && ( maxUniformBuffersPerDescriptor == rhs.maxUniformBuffersPerDescriptor )\r
+ && ( maxStorageBuffersPerDescriptor == rhs.maxStorageBuffersPerDescriptor )\r
+ && ( maxStorageImagesPerDescriptor == rhs.maxStorageImagesPerDescriptor )\r
+ && ( maxSampledImagesPerDescriptor == rhs.maxSampledImagesPerDescriptor )\r
+ && ( maxPipelineLayouts == rhs.maxPipelineLayouts );\r
+ }\r
+\r
+ bool operator!=( ObjectTableCreateInfoNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eObjectTableCreateInfoNVX;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t objectCount;\r
+ const ObjectEntryTypeNVX* pObjectEntryTypes;\r
+ const uint32_t* pObjectEntryCounts;\r
+ const ObjectEntryUsageFlagsNVX* pObjectEntryUsageFlags;\r
+ uint32_t maxUniformBuffersPerDescriptor;\r
+ uint32_t maxStorageBuffersPerDescriptor;\r
+ uint32_t maxStorageImagesPerDescriptor;\r
+ uint32_t maxSampledImagesPerDescriptor;\r
+ uint32_t maxPipelineLayouts;\r
+ };\r
+ static_assert( sizeof( ObjectTableCreateInfoNVX ) == sizeof( VkObjectTableCreateInfoNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct ObjectTableEntryNVX\r
+ {\r
+ ObjectTableEntryNVX( ObjectEntryTypeNVX type_ = ObjectEntryTypeNVX::eDescriptorSet, ObjectEntryUsageFlagsNVX flags_ = ObjectEntryUsageFlagsNVX() )\r
+ : type( type_ )\r
+ , flags( flags_ )\r
+ {\r
+ }\r
+\r
+ ObjectTableEntryNVX( VkObjectTableEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableEntryNVX ) );\r
+ }\r
+\r
+ ObjectTableEntryNVX& operator=( VkObjectTableEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableEntryNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTableEntryNVX& setType( ObjectEntryTypeNVX type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableEntryNVX& setFlags( ObjectEntryUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTableEntryNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTableEntryNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTableEntryNVX const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( flags == rhs.flags );\r
+ }\r
+\r
+ bool operator!=( ObjectTableEntryNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ObjectEntryTypeNVX type;\r
+ ObjectEntryUsageFlagsNVX flags;\r
+ };\r
+ static_assert( sizeof( ObjectTableEntryNVX ) == sizeof( VkObjectTableEntryNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct ObjectTablePipelineEntryNVX\r
+ {\r
+ ObjectTablePipelineEntryNVX( ObjectEntryTypeNVX type_ = ObjectEntryTypeNVX::eDescriptorSet, ObjectEntryUsageFlagsNVX flags_ = ObjectEntryUsageFlagsNVX(), Pipeline pipeline_ = Pipeline() )\r
+ : type( type_ )\r
+ , flags( flags_ )\r
+ , pipeline( pipeline_ )\r
+ {\r
+ }\r
+\r
+ ObjectTablePipelineEntryNVX( VkObjectTablePipelineEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTablePipelineEntryNVX ) );\r
+ }\r
+\r
+ ObjectTablePipelineEntryNVX& operator=( VkObjectTablePipelineEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTablePipelineEntryNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTablePipelineEntryNVX& setType( ObjectEntryTypeNVX type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTablePipelineEntryNVX& setFlags( ObjectEntryUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTablePipelineEntryNVX& setPipeline( Pipeline pipeline_ )\r
+ {\r
+ pipeline = pipeline_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTablePipelineEntryNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTablePipelineEntryNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTablePipelineEntryNVX const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( flags == rhs.flags )\r
+ && ( pipeline == rhs.pipeline );\r
+ }\r
+\r
+ bool operator!=( ObjectTablePipelineEntryNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ObjectEntryTypeNVX type;\r
+ ObjectEntryUsageFlagsNVX flags;\r
+ Pipeline pipeline;\r
+ };\r
+ static_assert( sizeof( ObjectTablePipelineEntryNVX ) == sizeof( VkObjectTablePipelineEntryNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct ObjectTableDescriptorSetEntryNVX\r
+ {\r
+ ObjectTableDescriptorSetEntryNVX( ObjectEntryTypeNVX type_ = ObjectEntryTypeNVX::eDescriptorSet, ObjectEntryUsageFlagsNVX flags_ = ObjectEntryUsageFlagsNVX(), PipelineLayout pipelineLayout_ = PipelineLayout(), DescriptorSet descriptorSet_ = DescriptorSet() )\r
+ : type( type_ )\r
+ , flags( flags_ )\r
+ , pipelineLayout( pipelineLayout_ )\r
+ , descriptorSet( descriptorSet_ )\r
+ {\r
+ }\r
+\r
+ ObjectTableDescriptorSetEntryNVX( VkObjectTableDescriptorSetEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableDescriptorSetEntryNVX ) );\r
+ }\r
+\r
+ ObjectTableDescriptorSetEntryNVX& operator=( VkObjectTableDescriptorSetEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableDescriptorSetEntryNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTableDescriptorSetEntryNVX& setType( ObjectEntryTypeNVX type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableDescriptorSetEntryNVX& setFlags( ObjectEntryUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableDescriptorSetEntryNVX& setPipelineLayout( PipelineLayout pipelineLayout_ )\r
+ {\r
+ pipelineLayout = pipelineLayout_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableDescriptorSetEntryNVX& setDescriptorSet( DescriptorSet descriptorSet_ )\r
+ {\r
+ descriptorSet = descriptorSet_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTableDescriptorSetEntryNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTableDescriptorSetEntryNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTableDescriptorSetEntryNVX const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( flags == rhs.flags )\r
+ && ( pipelineLayout == rhs.pipelineLayout )\r
+ && ( descriptorSet == rhs.descriptorSet );\r
+ }\r
+\r
+ bool operator!=( ObjectTableDescriptorSetEntryNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ObjectEntryTypeNVX type;\r
+ ObjectEntryUsageFlagsNVX flags;\r
+ PipelineLayout pipelineLayout;\r
+ DescriptorSet descriptorSet;\r
+ };\r
+ static_assert( sizeof( ObjectTableDescriptorSetEntryNVX ) == sizeof( VkObjectTableDescriptorSetEntryNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct ObjectTableVertexBufferEntryNVX\r
+ {\r
+ ObjectTableVertexBufferEntryNVX( ObjectEntryTypeNVX type_ = ObjectEntryTypeNVX::eDescriptorSet, ObjectEntryUsageFlagsNVX flags_ = ObjectEntryUsageFlagsNVX(), Buffer buffer_ = Buffer() )\r
+ : type( type_ )\r
+ , flags( flags_ )\r
+ , buffer( buffer_ )\r
+ {\r
+ }\r
+\r
+ ObjectTableVertexBufferEntryNVX( VkObjectTableVertexBufferEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableVertexBufferEntryNVX ) );\r
+ }\r
+\r
+ ObjectTableVertexBufferEntryNVX& operator=( VkObjectTableVertexBufferEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableVertexBufferEntryNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTableVertexBufferEntryNVX& setType( ObjectEntryTypeNVX type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableVertexBufferEntryNVX& setFlags( ObjectEntryUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableVertexBufferEntryNVX& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTableVertexBufferEntryNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTableVertexBufferEntryNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTableVertexBufferEntryNVX const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( flags == rhs.flags )\r
+ && ( buffer == rhs.buffer );\r
+ }\r
+\r
+ bool operator!=( ObjectTableVertexBufferEntryNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ObjectEntryTypeNVX type;\r
+ ObjectEntryUsageFlagsNVX flags;\r
+ Buffer buffer;\r
+ };\r
+ static_assert( sizeof( ObjectTableVertexBufferEntryNVX ) == sizeof( VkObjectTableVertexBufferEntryNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct ObjectTableIndexBufferEntryNVX\r
+ {\r
+ ObjectTableIndexBufferEntryNVX( ObjectEntryTypeNVX type_ = ObjectEntryTypeNVX::eDescriptorSet, ObjectEntryUsageFlagsNVX flags_ = ObjectEntryUsageFlagsNVX(), Buffer buffer_ = Buffer(), IndexType indexType_ = IndexType::eUint16 )\r
+ : type( type_ )\r
+ , flags( flags_ )\r
+ , buffer( buffer_ )\r
+ , indexType( indexType_ )\r
+ {\r
+ }\r
+\r
+ ObjectTableIndexBufferEntryNVX( VkObjectTableIndexBufferEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableIndexBufferEntryNVX ) );\r
+ }\r
+\r
+ ObjectTableIndexBufferEntryNVX& operator=( VkObjectTableIndexBufferEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTableIndexBufferEntryNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTableIndexBufferEntryNVX& setType( ObjectEntryTypeNVX type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableIndexBufferEntryNVX& setFlags( ObjectEntryUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableIndexBufferEntryNVX& setBuffer( Buffer buffer_ )\r
+ {\r
+ buffer = buffer_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTableIndexBufferEntryNVX& setIndexType( IndexType indexType_ )\r
+ {\r
+ indexType = indexType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTableIndexBufferEntryNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTableIndexBufferEntryNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTableIndexBufferEntryNVX const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( flags == rhs.flags )\r
+ && ( buffer == rhs.buffer )\r
+ && ( indexType == rhs.indexType );\r
+ }\r
+\r
+ bool operator!=( ObjectTableIndexBufferEntryNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ObjectEntryTypeNVX type;\r
+ ObjectEntryUsageFlagsNVX flags;\r
+ Buffer buffer;\r
+ IndexType indexType;\r
+ };\r
+ static_assert( sizeof( ObjectTableIndexBufferEntryNVX ) == sizeof( VkObjectTableIndexBufferEntryNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct ObjectTablePushConstantEntryNVX\r
+ {\r
+ ObjectTablePushConstantEntryNVX( ObjectEntryTypeNVX type_ = ObjectEntryTypeNVX::eDescriptorSet, ObjectEntryUsageFlagsNVX flags_ = ObjectEntryUsageFlagsNVX(), PipelineLayout pipelineLayout_ = PipelineLayout(), ShaderStageFlags stageFlags_ = ShaderStageFlags() )\r
+ : type( type_ )\r
+ , flags( flags_ )\r
+ , pipelineLayout( pipelineLayout_ )\r
+ , stageFlags( stageFlags_ )\r
+ {\r
+ }\r
+\r
+ ObjectTablePushConstantEntryNVX( VkObjectTablePushConstantEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTablePushConstantEntryNVX ) );\r
+ }\r
+\r
+ ObjectTablePushConstantEntryNVX& operator=( VkObjectTablePushConstantEntryNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ObjectTablePushConstantEntryNVX ) );\r
+ return *this;\r
+ }\r
+ ObjectTablePushConstantEntryNVX& setType( ObjectEntryTypeNVX type_ )\r
+ {\r
+ type = type_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTablePushConstantEntryNVX& setFlags( ObjectEntryUsageFlagsNVX flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTablePushConstantEntryNVX& setPipelineLayout( PipelineLayout pipelineLayout_ )\r
+ {\r
+ pipelineLayout = pipelineLayout_;\r
+ return *this;\r
+ }\r
+\r
+ ObjectTablePushConstantEntryNVX& setStageFlags( ShaderStageFlags stageFlags_ )\r
+ {\r
+ stageFlags = stageFlags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkObjectTablePushConstantEntryNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkObjectTablePushConstantEntryNVX*>(this);\r
+ }\r
+\r
+ bool operator==( ObjectTablePushConstantEntryNVX const& rhs ) const\r
+ {\r
+ return ( type == rhs.type )\r
+ && ( flags == rhs.flags )\r
+ && ( pipelineLayout == rhs.pipelineLayout )\r
+ && ( stageFlags == rhs.stageFlags );\r
+ }\r
+\r
+ bool operator!=( ObjectTablePushConstantEntryNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ObjectEntryTypeNVX type;\r
+ ObjectEntryUsageFlagsNVX flags;\r
+ PipelineLayout pipelineLayout;\r
+ ShaderStageFlags stageFlags;\r
+ };\r
+ static_assert( sizeof( ObjectTablePushConstantEntryNVX ) == sizeof( VkObjectTablePushConstantEntryNVX ), "struct and wrapper have different size!" );\r
+\r
+ enum class DescriptorSetLayoutCreateFlagBits\r
+ {\r
+ ePushDescriptorKHR = VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR,\r
+ eUpdateAfterBindPoolEXT = VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT\r
+ };\r
+\r
+ using DescriptorSetLayoutCreateFlags = Flags<DescriptorSetLayoutCreateFlagBits, VkDescriptorSetLayoutCreateFlags>;\r
+\r
+ VULKAN_HPP_INLINE DescriptorSetLayoutCreateFlags operator|( DescriptorSetLayoutCreateFlagBits bit0, DescriptorSetLayoutCreateFlagBits bit1 )\r
+ {\r
+ return DescriptorSetLayoutCreateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DescriptorSetLayoutCreateFlags operator~( DescriptorSetLayoutCreateFlagBits bits )\r
+ {\r
+ return ~( DescriptorSetLayoutCreateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DescriptorSetLayoutCreateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DescriptorSetLayoutCreateFlagBits::ePushDescriptorKHR) | VkFlags(DescriptorSetLayoutCreateFlagBits::eUpdateAfterBindPoolEXT)\r
+ };\r
+ };\r
+\r
+ struct DescriptorSetLayoutCreateInfo\r
+ {\r
+ DescriptorSetLayoutCreateInfo( DescriptorSetLayoutCreateFlags flags_ = DescriptorSetLayoutCreateFlags(), uint32_t bindingCount_ = 0, const DescriptorSetLayoutBinding* pBindings_ = nullptr )\r
+ : flags( flags_ )\r
+ , bindingCount( bindingCount_ )\r
+ , pBindings( pBindings_ )\r
+ {\r
+ }\r
+\r
+ DescriptorSetLayoutCreateInfo( VkDescriptorSetLayoutCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetLayoutCreateInfo ) );\r
+ }\r
+\r
+ DescriptorSetLayoutCreateInfo& operator=( VkDescriptorSetLayoutCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetLayoutCreateInfo ) );\r
+ return *this;\r
+ }\r
+ DescriptorSetLayoutCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutCreateInfo& setFlags( DescriptorSetLayoutCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutCreateInfo& setBindingCount( uint32_t bindingCount_ )\r
+ {\r
+ bindingCount = bindingCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutCreateInfo& setPBindings( const DescriptorSetLayoutBinding* pBindings_ )\r
+ {\r
+ pBindings = pBindings_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorSetLayoutCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetLayoutCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( bindingCount == rhs.bindingCount )\r
+ && ( pBindings == rhs.pBindings );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetLayoutCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorSetLayoutCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DescriptorSetLayoutCreateFlags flags;\r
+ uint32_t bindingCount;\r
+ const DescriptorSetLayoutBinding* pBindings;\r
+ };\r
+ static_assert( sizeof( DescriptorSetLayoutCreateInfo ) == sizeof( VkDescriptorSetLayoutCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class ExternalMemoryHandleTypeFlagBits\r
+ {\r
+ eOpaqueFd = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT,\r
+ eOpaqueFdKHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT,\r
+ eOpaqueWin32 = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT,\r
+ eOpaqueWin32KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT,\r
+ eOpaqueWin32Kmt = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,\r
+ eOpaqueWin32KmtKHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,\r
+ eD3D11Texture = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT,\r
+ eD3D11TextureKHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT,\r
+ eD3D11TextureKmt = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT,\r
+ eD3D11TextureKmtKHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT,\r
+ eD3D12Heap = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT,\r
+ eD3D12HeapKHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT,\r
+ eD3D12Resource = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT,\r
+ eD3D12ResourceKHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT,\r
+ eDmaBufEXT = VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT,\r
+ eAndroidHardwareBufferANDROID = VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID,\r
+ eHostAllocationEXT = VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT,\r
+ eHostMappedForeignMemoryEXT = VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT\r
+ };\r
+\r
+ using ExternalMemoryHandleTypeFlags = Flags<ExternalMemoryHandleTypeFlagBits, VkExternalMemoryHandleTypeFlags>;\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryHandleTypeFlags operator|( ExternalMemoryHandleTypeFlagBits bit0, ExternalMemoryHandleTypeFlagBits bit1 )\r
+ {\r
+ return ExternalMemoryHandleTypeFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryHandleTypeFlags operator~( ExternalMemoryHandleTypeFlagBits bits )\r
+ {\r
+ return ~( ExternalMemoryHandleTypeFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalMemoryHandleTypeFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalMemoryHandleTypeFlagBits::eOpaqueFd) | VkFlags(ExternalMemoryHandleTypeFlagBits::eOpaqueWin32) | VkFlags(ExternalMemoryHandleTypeFlagBits::eOpaqueWin32Kmt) | VkFlags(ExternalMemoryHandleTypeFlagBits::eD3D11Texture) | VkFlags(ExternalMemoryHandleTypeFlagBits::eD3D11TextureKmt) | VkFlags(ExternalMemoryHandleTypeFlagBits::eD3D12Heap) | VkFlags(ExternalMemoryHandleTypeFlagBits::eD3D12Resource) | VkFlags(ExternalMemoryHandleTypeFlagBits::eDmaBufEXT) | VkFlags(ExternalMemoryHandleTypeFlagBits::eAndroidHardwareBufferANDROID) | VkFlags(ExternalMemoryHandleTypeFlagBits::eHostAllocationEXT) | VkFlags(ExternalMemoryHandleTypeFlagBits::eHostMappedForeignMemoryEXT)\r
+ };\r
+ };\r
+\r
+ using ExternalMemoryHandleTypeFlagsKHR = ExternalMemoryHandleTypeFlags;\r
+\r
+ struct PhysicalDeviceExternalImageFormatInfo\r
+ {\r
+ PhysicalDeviceExternalImageFormatInfo( ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd )\r
+ : handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceExternalImageFormatInfo( VkPhysicalDeviceExternalImageFormatInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalImageFormatInfo ) );\r
+ }\r
+\r
+ PhysicalDeviceExternalImageFormatInfo& operator=( VkPhysicalDeviceExternalImageFormatInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalImageFormatInfo ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceExternalImageFormatInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalImageFormatInfo& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceExternalImageFormatInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceExternalImageFormatInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceExternalImageFormatInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceExternalImageFormatInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceExternalImageFormatInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceExternalImageFormatInfo ) == sizeof( VkPhysicalDeviceExternalImageFormatInfo ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceExternalImageFormatInfoKHR = PhysicalDeviceExternalImageFormatInfo;\r
+\r
+ struct PhysicalDeviceExternalBufferInfo\r
+ {\r
+ PhysicalDeviceExternalBufferInfo( BufferCreateFlags flags_ = BufferCreateFlags(), BufferUsageFlags usage_ = BufferUsageFlags(), ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd )\r
+ : flags( flags_ )\r
+ , usage( usage_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceExternalBufferInfo( VkPhysicalDeviceExternalBufferInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalBufferInfo ) );\r
+ }\r
+\r
+ PhysicalDeviceExternalBufferInfo& operator=( VkPhysicalDeviceExternalBufferInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalBufferInfo ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceExternalBufferInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalBufferInfo& setFlags( BufferCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalBufferInfo& setUsage( BufferUsageFlags usage_ )\r
+ {\r
+ usage = usage_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalBufferInfo& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceExternalBufferInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceExternalBufferInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceExternalBufferInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( usage == rhs.usage )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceExternalBufferInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceExternalBufferInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ BufferCreateFlags flags;\r
+ BufferUsageFlags usage;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceExternalBufferInfo ) == sizeof( VkPhysicalDeviceExternalBufferInfo ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceExternalBufferInfoKHR = PhysicalDeviceExternalBufferInfo;\r
+\r
+ struct ExternalMemoryImageCreateInfo\r
+ {\r
+ ExternalMemoryImageCreateInfo( ExternalMemoryHandleTypeFlags handleTypes_ = ExternalMemoryHandleTypeFlags() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExternalMemoryImageCreateInfo( VkExternalMemoryImageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalMemoryImageCreateInfo ) );\r
+ }\r
+\r
+ ExternalMemoryImageCreateInfo& operator=( VkExternalMemoryImageCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalMemoryImageCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ExternalMemoryImageCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExternalMemoryImageCreateInfo& setHandleTypes( ExternalMemoryHandleTypeFlags handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExternalMemoryImageCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalMemoryImageCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalMemoryImageCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExternalMemoryImageCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalMemoryImageCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlags handleTypes;\r
+ };\r
+ static_assert( sizeof( ExternalMemoryImageCreateInfo ) == sizeof( VkExternalMemoryImageCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalMemoryImageCreateInfoKHR = ExternalMemoryImageCreateInfo;\r
+\r
+ struct ExternalMemoryBufferCreateInfo\r
+ {\r
+ ExternalMemoryBufferCreateInfo( ExternalMemoryHandleTypeFlags handleTypes_ = ExternalMemoryHandleTypeFlags() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExternalMemoryBufferCreateInfo( VkExternalMemoryBufferCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalMemoryBufferCreateInfo ) );\r
+ }\r
+\r
+ ExternalMemoryBufferCreateInfo& operator=( VkExternalMemoryBufferCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExternalMemoryBufferCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ExternalMemoryBufferCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExternalMemoryBufferCreateInfo& setHandleTypes( ExternalMemoryHandleTypeFlags handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExternalMemoryBufferCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalMemoryBufferCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalMemoryBufferCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExternalMemoryBufferCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalMemoryBufferCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlags handleTypes;\r
+ };\r
+ static_assert( sizeof( ExternalMemoryBufferCreateInfo ) == sizeof( VkExternalMemoryBufferCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalMemoryBufferCreateInfoKHR = ExternalMemoryBufferCreateInfo;\r
+\r
+ struct ExportMemoryAllocateInfo\r
+ {\r
+ ExportMemoryAllocateInfo( ExternalMemoryHandleTypeFlags handleTypes_ = ExternalMemoryHandleTypeFlags() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExportMemoryAllocateInfo( VkExportMemoryAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryAllocateInfo ) );\r
+ }\r
+\r
+ ExportMemoryAllocateInfo& operator=( VkExportMemoryAllocateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportMemoryAllocateInfo ) );\r
+ return *this;\r
+ }\r
+ ExportMemoryAllocateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportMemoryAllocateInfo& setHandleTypes( ExternalMemoryHandleTypeFlags handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportMemoryAllocateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportMemoryAllocateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ExportMemoryAllocateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExportMemoryAllocateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportMemoryAllocateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlags handleTypes;\r
+ };\r
+ static_assert( sizeof( ExportMemoryAllocateInfo ) == sizeof( VkExportMemoryAllocateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ExportMemoryAllocateInfoKHR = ExportMemoryAllocateInfo;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct ImportMemoryWin32HandleInfoKHR\r
+ {\r
+ ImportMemoryWin32HandleInfoKHR( ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd, HANDLE handle_ = 0, LPCWSTR name_ = 0 )\r
+ : handleType( handleType_ )\r
+ , handle( handle_ )\r
+ , name( name_ )\r
+ {\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoKHR( VkImportMemoryWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoKHR& operator=( VkImportMemoryWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImportMemoryWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoKHR& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoKHR& setHandle( HANDLE handle_ )\r
+ {\r
+ handle = handle_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryWin32HandleInfoKHR& setName( LPCWSTR name_ )\r
+ {\r
+ name = name_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportMemoryWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportMemoryWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImportMemoryWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType )\r
+ && ( handle == rhs.handle )\r
+ && ( name == rhs.name );\r
+ }\r
+\r
+ bool operator!=( ImportMemoryWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportMemoryWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ HANDLE handle;\r
+ LPCWSTR name;\r
+ };\r
+ static_assert( sizeof( ImportMemoryWin32HandleInfoKHR ) == sizeof( VkImportMemoryWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct MemoryGetWin32HandleInfoKHR\r
+ {\r
+ MemoryGetWin32HandleInfoKHR( DeviceMemory memory_ = DeviceMemory(), ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd )\r
+ : memory( memory_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ MemoryGetWin32HandleInfoKHR( VkMemoryGetWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryGetWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ MemoryGetWin32HandleInfoKHR& operator=( VkMemoryGetWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryGetWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ MemoryGetWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryGetWin32HandleInfoKHR& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryGetWin32HandleInfoKHR& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryGetWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryGetWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryGetWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memory == rhs.memory )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( MemoryGetWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryGetWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceMemory memory;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( MemoryGetWin32HandleInfoKHR ) == sizeof( VkMemoryGetWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct ImportMemoryFdInfoKHR\r
+ {\r
+ ImportMemoryFdInfoKHR( ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd, int fd_ = 0 )\r
+ : handleType( handleType_ )\r
+ , fd( fd_ )\r
+ {\r
+ }\r
+\r
+ ImportMemoryFdInfoKHR( VkImportMemoryFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryFdInfoKHR ) );\r
+ }\r
+\r
+ ImportMemoryFdInfoKHR& operator=( VkImportMemoryFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryFdInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImportMemoryFdInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryFdInfoKHR& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryFdInfoKHR& setFd( int fd_ )\r
+ {\r
+ fd = fd_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportMemoryFdInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportMemoryFdInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImportMemoryFdInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType )\r
+ && ( fd == rhs.fd );\r
+ }\r
+\r
+ bool operator!=( ImportMemoryFdInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportMemoryFdInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ int fd;\r
+ };\r
+ static_assert( sizeof( ImportMemoryFdInfoKHR ) == sizeof( VkImportMemoryFdInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct MemoryGetFdInfoKHR\r
+ {\r
+ MemoryGetFdInfoKHR( DeviceMemory memory_ = DeviceMemory(), ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd )\r
+ : memory( memory_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ MemoryGetFdInfoKHR( VkMemoryGetFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryGetFdInfoKHR ) );\r
+ }\r
+\r
+ MemoryGetFdInfoKHR& operator=( VkMemoryGetFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryGetFdInfoKHR ) );\r
+ return *this;\r
+ }\r
+ MemoryGetFdInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryGetFdInfoKHR& setMemory( DeviceMemory memory_ )\r
+ {\r
+ memory = memory_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryGetFdInfoKHR& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryGetFdInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryGetFdInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryGetFdInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memory == rhs.memory )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( MemoryGetFdInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryGetFdInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceMemory memory;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( MemoryGetFdInfoKHR ) == sizeof( VkMemoryGetFdInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct ImportMemoryHostPointerInfoEXT\r
+ {\r
+ ImportMemoryHostPointerInfoEXT( ExternalMemoryHandleTypeFlagBits handleType_ = ExternalMemoryHandleTypeFlagBits::eOpaqueFd, void* pHostPointer_ = nullptr )\r
+ : handleType( handleType_ )\r
+ , pHostPointer( pHostPointer_ )\r
+ {\r
+ }\r
+\r
+ ImportMemoryHostPointerInfoEXT( VkImportMemoryHostPointerInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryHostPointerInfoEXT ) );\r
+ }\r
+\r
+ ImportMemoryHostPointerInfoEXT& operator=( VkImportMemoryHostPointerInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportMemoryHostPointerInfoEXT ) );\r
+ return *this;\r
+ }\r
+ ImportMemoryHostPointerInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryHostPointerInfoEXT& setHandleType( ExternalMemoryHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportMemoryHostPointerInfoEXT& setPHostPointer( void* pHostPointer_ )\r
+ {\r
+ pHostPointer = pHostPointer_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportMemoryHostPointerInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportMemoryHostPointerInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( ImportMemoryHostPointerInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType )\r
+ && ( pHostPointer == rhs.pHostPointer );\r
+ }\r
+\r
+ bool operator!=( ImportMemoryHostPointerInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportMemoryHostPointerInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalMemoryHandleTypeFlagBits handleType;\r
+ void* pHostPointer;\r
+ };\r
+ static_assert( sizeof( ImportMemoryHostPointerInfoEXT ) == sizeof( VkImportMemoryHostPointerInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class ExternalMemoryFeatureFlagBits\r
+ {\r
+ eDedicatedOnly = VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT,\r
+ eDedicatedOnlyKHR = VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT,\r
+ eExportable = VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT,\r
+ eExportableKHR = VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT,\r
+ eImportable = VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT,\r
+ eImportableKHR = VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT\r
+ };\r
+\r
+ using ExternalMemoryFeatureFlags = Flags<ExternalMemoryFeatureFlagBits, VkExternalMemoryFeatureFlags>;\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryFeatureFlags operator|( ExternalMemoryFeatureFlagBits bit0, ExternalMemoryFeatureFlagBits bit1 )\r
+ {\r
+ return ExternalMemoryFeatureFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalMemoryFeatureFlags operator~( ExternalMemoryFeatureFlagBits bits )\r
+ {\r
+ return ~( ExternalMemoryFeatureFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalMemoryFeatureFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalMemoryFeatureFlagBits::eDedicatedOnly) | VkFlags(ExternalMemoryFeatureFlagBits::eExportable) | VkFlags(ExternalMemoryFeatureFlagBits::eImportable)\r
+ };\r
+ };\r
+\r
+ using ExternalMemoryFeatureFlagsKHR = ExternalMemoryFeatureFlags;\r
+\r
+ struct ExternalMemoryProperties\r
+ {\r
+ operator const VkExternalMemoryProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalMemoryProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalMemoryProperties const& rhs ) const\r
+ {\r
+ return ( externalMemoryFeatures == rhs.externalMemoryFeatures )\r
+ && ( exportFromImportedHandleTypes == rhs.exportFromImportedHandleTypes )\r
+ && ( compatibleHandleTypes == rhs.compatibleHandleTypes );\r
+ }\r
+\r
+ bool operator!=( ExternalMemoryProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ExternalMemoryFeatureFlags externalMemoryFeatures;\r
+ ExternalMemoryHandleTypeFlags exportFromImportedHandleTypes;\r
+ ExternalMemoryHandleTypeFlags compatibleHandleTypes;\r
+ };\r
+ static_assert( sizeof( ExternalMemoryProperties ) == sizeof( VkExternalMemoryProperties ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalMemoryPropertiesKHR = ExternalMemoryProperties;\r
+\r
+ struct ExternalImageFormatProperties\r
+ {\r
+ operator const VkExternalImageFormatProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalImageFormatProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalImageFormatProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( externalMemoryProperties == rhs.externalMemoryProperties );\r
+ }\r
+\r
+ bool operator!=( ExternalImageFormatProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalImageFormatProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ ExternalMemoryProperties externalMemoryProperties;\r
+ };\r
+ static_assert( sizeof( ExternalImageFormatProperties ) == sizeof( VkExternalImageFormatProperties ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalImageFormatPropertiesKHR = ExternalImageFormatProperties;\r
+\r
+ struct ExternalBufferProperties\r
+ {\r
+ operator const VkExternalBufferProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalBufferProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalBufferProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( externalMemoryProperties == rhs.externalMemoryProperties );\r
+ }\r
+\r
+ bool operator!=( ExternalBufferProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalBufferProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ ExternalMemoryProperties externalMemoryProperties;\r
+ };\r
+ static_assert( sizeof( ExternalBufferProperties ) == sizeof( VkExternalBufferProperties ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalBufferPropertiesKHR = ExternalBufferProperties;\r
+\r
+ enum class ExternalSemaphoreHandleTypeFlagBits\r
+ {\r
+ eOpaqueFd = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT,\r
+ eOpaqueFdKHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT,\r
+ eOpaqueWin32 = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT,\r
+ eOpaqueWin32KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT,\r
+ eOpaqueWin32Kmt = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,\r
+ eOpaqueWin32KmtKHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,\r
+ eD3D12Fence = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT,\r
+ eD3D12FenceKHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT,\r
+ eSyncFd = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT,\r
+ eSyncFdKHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT\r
+ };\r
+\r
+ using ExternalSemaphoreHandleTypeFlags = Flags<ExternalSemaphoreHandleTypeFlagBits, VkExternalSemaphoreHandleTypeFlags>;\r
+\r
+ VULKAN_HPP_INLINE ExternalSemaphoreHandleTypeFlags operator|( ExternalSemaphoreHandleTypeFlagBits bit0, ExternalSemaphoreHandleTypeFlagBits bit1 )\r
+ {\r
+ return ExternalSemaphoreHandleTypeFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalSemaphoreHandleTypeFlags operator~( ExternalSemaphoreHandleTypeFlagBits bits )\r
+ {\r
+ return ~( ExternalSemaphoreHandleTypeFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalSemaphoreHandleTypeFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd) | VkFlags(ExternalSemaphoreHandleTypeFlagBits::eOpaqueWin32) | VkFlags(ExternalSemaphoreHandleTypeFlagBits::eOpaqueWin32Kmt) | VkFlags(ExternalSemaphoreHandleTypeFlagBits::eD3D12Fence) | VkFlags(ExternalSemaphoreHandleTypeFlagBits::eSyncFd)\r
+ };\r
+ };\r
+\r
+ using ExternalSemaphoreHandleTypeFlagsKHR = ExternalSemaphoreHandleTypeFlags;\r
+\r
+ struct PhysicalDeviceExternalSemaphoreInfo\r
+ {\r
+ PhysicalDeviceExternalSemaphoreInfo( ExternalSemaphoreHandleTypeFlagBits handleType_ = ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd )\r
+ : handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceExternalSemaphoreInfo( VkPhysicalDeviceExternalSemaphoreInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalSemaphoreInfo ) );\r
+ }\r
+\r
+ PhysicalDeviceExternalSemaphoreInfo& operator=( VkPhysicalDeviceExternalSemaphoreInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalSemaphoreInfo ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceExternalSemaphoreInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalSemaphoreInfo& setHandleType( ExternalSemaphoreHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceExternalSemaphoreInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceExternalSemaphoreInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceExternalSemaphoreInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceExternalSemaphoreInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceExternalSemaphoreInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalSemaphoreHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceExternalSemaphoreInfo ) == sizeof( VkPhysicalDeviceExternalSemaphoreInfo ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceExternalSemaphoreInfoKHR = PhysicalDeviceExternalSemaphoreInfo;\r
+\r
+ struct ExportSemaphoreCreateInfo\r
+ {\r
+ ExportSemaphoreCreateInfo( ExternalSemaphoreHandleTypeFlags handleTypes_ = ExternalSemaphoreHandleTypeFlags() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExportSemaphoreCreateInfo( VkExportSemaphoreCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportSemaphoreCreateInfo ) );\r
+ }\r
+\r
+ ExportSemaphoreCreateInfo& operator=( VkExportSemaphoreCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportSemaphoreCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ExportSemaphoreCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportSemaphoreCreateInfo& setHandleTypes( ExternalSemaphoreHandleTypeFlags handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportSemaphoreCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportSemaphoreCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ExportSemaphoreCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExportSemaphoreCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportSemaphoreCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalSemaphoreHandleTypeFlags handleTypes;\r
+ };\r
+ static_assert( sizeof( ExportSemaphoreCreateInfo ) == sizeof( VkExportSemaphoreCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ExportSemaphoreCreateInfoKHR = ExportSemaphoreCreateInfo;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct SemaphoreGetWin32HandleInfoKHR\r
+ {\r
+ SemaphoreGetWin32HandleInfoKHR( Semaphore semaphore_ = Semaphore(), ExternalSemaphoreHandleTypeFlagBits handleType_ = ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd )\r
+ : semaphore( semaphore_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ SemaphoreGetWin32HandleInfoKHR( VkSemaphoreGetWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SemaphoreGetWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ SemaphoreGetWin32HandleInfoKHR& operator=( VkSemaphoreGetWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SemaphoreGetWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ SemaphoreGetWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SemaphoreGetWin32HandleInfoKHR& setSemaphore( Semaphore semaphore_ )\r
+ {\r
+ semaphore = semaphore_;\r
+ return *this;\r
+ }\r
+\r
+ SemaphoreGetWin32HandleInfoKHR& setHandleType( ExternalSemaphoreHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSemaphoreGetWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSemaphoreGetWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( SemaphoreGetWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( semaphore == rhs.semaphore )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( SemaphoreGetWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSemaphoreGetWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Semaphore semaphore;\r
+ ExternalSemaphoreHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( SemaphoreGetWin32HandleInfoKHR ) == sizeof( VkSemaphoreGetWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct SemaphoreGetFdInfoKHR\r
+ {\r
+ SemaphoreGetFdInfoKHR( Semaphore semaphore_ = Semaphore(), ExternalSemaphoreHandleTypeFlagBits handleType_ = ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd )\r
+ : semaphore( semaphore_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ SemaphoreGetFdInfoKHR( VkSemaphoreGetFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SemaphoreGetFdInfoKHR ) );\r
+ }\r
+\r
+ SemaphoreGetFdInfoKHR& operator=( VkSemaphoreGetFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SemaphoreGetFdInfoKHR ) );\r
+ return *this;\r
+ }\r
+ SemaphoreGetFdInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SemaphoreGetFdInfoKHR& setSemaphore( Semaphore semaphore_ )\r
+ {\r
+ semaphore = semaphore_;\r
+ return *this;\r
+ }\r
+\r
+ SemaphoreGetFdInfoKHR& setHandleType( ExternalSemaphoreHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSemaphoreGetFdInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSemaphoreGetFdInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( SemaphoreGetFdInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( semaphore == rhs.semaphore )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( SemaphoreGetFdInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSemaphoreGetFdInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Semaphore semaphore;\r
+ ExternalSemaphoreHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( SemaphoreGetFdInfoKHR ) == sizeof( VkSemaphoreGetFdInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class ExternalSemaphoreFeatureFlagBits\r
+ {\r
+ eExportable = VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT,\r
+ eExportableKHR = VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT,\r
+ eImportable = VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT,\r
+ eImportableKHR = VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT\r
+ };\r
+\r
+ using ExternalSemaphoreFeatureFlags = Flags<ExternalSemaphoreFeatureFlagBits, VkExternalSemaphoreFeatureFlags>;\r
+\r
+ VULKAN_HPP_INLINE ExternalSemaphoreFeatureFlags operator|( ExternalSemaphoreFeatureFlagBits bit0, ExternalSemaphoreFeatureFlagBits bit1 )\r
+ {\r
+ return ExternalSemaphoreFeatureFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalSemaphoreFeatureFlags operator~( ExternalSemaphoreFeatureFlagBits bits )\r
+ {\r
+ return ~( ExternalSemaphoreFeatureFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalSemaphoreFeatureFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalSemaphoreFeatureFlagBits::eExportable) | VkFlags(ExternalSemaphoreFeatureFlagBits::eImportable)\r
+ };\r
+ };\r
+\r
+ using ExternalSemaphoreFeatureFlagsKHR = ExternalSemaphoreFeatureFlags;\r
+\r
+ struct ExternalSemaphoreProperties\r
+ {\r
+ operator const VkExternalSemaphoreProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalSemaphoreProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalSemaphoreProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( exportFromImportedHandleTypes == rhs.exportFromImportedHandleTypes )\r
+ && ( compatibleHandleTypes == rhs.compatibleHandleTypes )\r
+ && ( externalSemaphoreFeatures == rhs.externalSemaphoreFeatures );\r
+ }\r
+\r
+ bool operator!=( ExternalSemaphoreProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalSemaphoreProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ ExternalSemaphoreHandleTypeFlags exportFromImportedHandleTypes;\r
+ ExternalSemaphoreHandleTypeFlags compatibleHandleTypes;\r
+ ExternalSemaphoreFeatureFlags externalSemaphoreFeatures;\r
+ };\r
+ static_assert( sizeof( ExternalSemaphoreProperties ) == sizeof( VkExternalSemaphoreProperties ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalSemaphorePropertiesKHR = ExternalSemaphoreProperties;\r
+\r
+ enum class SemaphoreImportFlagBits\r
+ {\r
+ eTemporary = VK_SEMAPHORE_IMPORT_TEMPORARY_BIT,\r
+ eTemporaryKHR = VK_SEMAPHORE_IMPORT_TEMPORARY_BIT\r
+ };\r
+\r
+ using SemaphoreImportFlags = Flags<SemaphoreImportFlagBits, VkSemaphoreImportFlags>;\r
+\r
+ VULKAN_HPP_INLINE SemaphoreImportFlags operator|( SemaphoreImportFlagBits bit0, SemaphoreImportFlagBits bit1 )\r
+ {\r
+ return SemaphoreImportFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SemaphoreImportFlags operator~( SemaphoreImportFlagBits bits )\r
+ {\r
+ return ~( SemaphoreImportFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SemaphoreImportFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SemaphoreImportFlagBits::eTemporary)\r
+ };\r
+ };\r
+\r
+ using SemaphoreImportFlagsKHR = SemaphoreImportFlags;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct ImportSemaphoreWin32HandleInfoKHR\r
+ {\r
+ ImportSemaphoreWin32HandleInfoKHR( Semaphore semaphore_ = Semaphore(), SemaphoreImportFlags flags_ = SemaphoreImportFlags(), ExternalSemaphoreHandleTypeFlagBits handleType_ = ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd, HANDLE handle_ = 0, LPCWSTR name_ = 0 )\r
+ : semaphore( semaphore_ )\r
+ , flags( flags_ )\r
+ , handleType( handleType_ )\r
+ , handle( handle_ )\r
+ , name( name_ )\r
+ {\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR( VkImportSemaphoreWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportSemaphoreWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR& operator=( VkImportSemaphoreWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportSemaphoreWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImportSemaphoreWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR& setSemaphore( Semaphore semaphore_ )\r
+ {\r
+ semaphore = semaphore_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR& setFlags( SemaphoreImportFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR& setHandleType( ExternalSemaphoreHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR& setHandle( HANDLE handle_ )\r
+ {\r
+ handle = handle_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreWin32HandleInfoKHR& setName( LPCWSTR name_ )\r
+ {\r
+ name = name_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportSemaphoreWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportSemaphoreWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImportSemaphoreWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( semaphore == rhs.semaphore )\r
+ && ( flags == rhs.flags )\r
+ && ( handleType == rhs.handleType )\r
+ && ( handle == rhs.handle )\r
+ && ( name == rhs.name );\r
+ }\r
+\r
+ bool operator!=( ImportSemaphoreWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportSemaphoreWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Semaphore semaphore;\r
+ SemaphoreImportFlags flags;\r
+ ExternalSemaphoreHandleTypeFlagBits handleType;\r
+ HANDLE handle;\r
+ LPCWSTR name;\r
+ };\r
+ static_assert( sizeof( ImportSemaphoreWin32HandleInfoKHR ) == sizeof( VkImportSemaphoreWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct ImportSemaphoreFdInfoKHR\r
+ {\r
+ ImportSemaphoreFdInfoKHR( Semaphore semaphore_ = Semaphore(), SemaphoreImportFlags flags_ = SemaphoreImportFlags(), ExternalSemaphoreHandleTypeFlagBits handleType_ = ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd, int fd_ = 0 )\r
+ : semaphore( semaphore_ )\r
+ , flags( flags_ )\r
+ , handleType( handleType_ )\r
+ , fd( fd_ )\r
+ {\r
+ }\r
+\r
+ ImportSemaphoreFdInfoKHR( VkImportSemaphoreFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportSemaphoreFdInfoKHR ) );\r
+ }\r
+\r
+ ImportSemaphoreFdInfoKHR& operator=( VkImportSemaphoreFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportSemaphoreFdInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImportSemaphoreFdInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreFdInfoKHR& setSemaphore( Semaphore semaphore_ )\r
+ {\r
+ semaphore = semaphore_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreFdInfoKHR& setFlags( SemaphoreImportFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreFdInfoKHR& setHandleType( ExternalSemaphoreHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportSemaphoreFdInfoKHR& setFd( int fd_ )\r
+ {\r
+ fd = fd_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportSemaphoreFdInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportSemaphoreFdInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImportSemaphoreFdInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( semaphore == rhs.semaphore )\r
+ && ( flags == rhs.flags )\r
+ && ( handleType == rhs.handleType )\r
+ && ( fd == rhs.fd );\r
+ }\r
+\r
+ bool operator!=( ImportSemaphoreFdInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportSemaphoreFdInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Semaphore semaphore;\r
+ SemaphoreImportFlags flags;\r
+ ExternalSemaphoreHandleTypeFlagBits handleType;\r
+ int fd;\r
+ };\r
+ static_assert( sizeof( ImportSemaphoreFdInfoKHR ) == sizeof( VkImportSemaphoreFdInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class ExternalFenceHandleTypeFlagBits\r
+ {\r
+ eOpaqueFd = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT,\r
+ eOpaqueFdKHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT,\r
+ eOpaqueWin32 = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT,\r
+ eOpaqueWin32KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT,\r
+ eOpaqueWin32Kmt = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,\r
+ eOpaqueWin32KmtKHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,\r
+ eSyncFd = VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT,\r
+ eSyncFdKHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT\r
+ };\r
+\r
+ using ExternalFenceHandleTypeFlags = Flags<ExternalFenceHandleTypeFlagBits, VkExternalFenceHandleTypeFlags>;\r
+\r
+ VULKAN_HPP_INLINE ExternalFenceHandleTypeFlags operator|( ExternalFenceHandleTypeFlagBits bit0, ExternalFenceHandleTypeFlagBits bit1 )\r
+ {\r
+ return ExternalFenceHandleTypeFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalFenceHandleTypeFlags operator~( ExternalFenceHandleTypeFlagBits bits )\r
+ {\r
+ return ~( ExternalFenceHandleTypeFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalFenceHandleTypeFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalFenceHandleTypeFlagBits::eOpaqueFd) | VkFlags(ExternalFenceHandleTypeFlagBits::eOpaqueWin32) | VkFlags(ExternalFenceHandleTypeFlagBits::eOpaqueWin32Kmt) | VkFlags(ExternalFenceHandleTypeFlagBits::eSyncFd)\r
+ };\r
+ };\r
+\r
+ using ExternalFenceHandleTypeFlagsKHR = ExternalFenceHandleTypeFlags;\r
+\r
+ struct PhysicalDeviceExternalFenceInfo\r
+ {\r
+ PhysicalDeviceExternalFenceInfo( ExternalFenceHandleTypeFlagBits handleType_ = ExternalFenceHandleTypeFlagBits::eOpaqueFd )\r
+ : handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ PhysicalDeviceExternalFenceInfo( VkPhysicalDeviceExternalFenceInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalFenceInfo ) );\r
+ }\r
+\r
+ PhysicalDeviceExternalFenceInfo& operator=( VkPhysicalDeviceExternalFenceInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PhysicalDeviceExternalFenceInfo ) );\r
+ return *this;\r
+ }\r
+ PhysicalDeviceExternalFenceInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PhysicalDeviceExternalFenceInfo& setHandleType( ExternalFenceHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPhysicalDeviceExternalFenceInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceExternalFenceInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceExternalFenceInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceExternalFenceInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceExternalFenceInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalFenceHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceExternalFenceInfo ) == sizeof( VkPhysicalDeviceExternalFenceInfo ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceExternalFenceInfoKHR = PhysicalDeviceExternalFenceInfo;\r
+\r
+ struct ExportFenceCreateInfo\r
+ {\r
+ ExportFenceCreateInfo( ExternalFenceHandleTypeFlags handleTypes_ = ExternalFenceHandleTypeFlags() )\r
+ : handleTypes( handleTypes_ )\r
+ {\r
+ }\r
+\r
+ ExportFenceCreateInfo( VkExportFenceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportFenceCreateInfo ) );\r
+ }\r
+\r
+ ExportFenceCreateInfo& operator=( VkExportFenceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ExportFenceCreateInfo ) );\r
+ return *this;\r
+ }\r
+ ExportFenceCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ExportFenceCreateInfo& setHandleTypes( ExternalFenceHandleTypeFlags handleTypes_ )\r
+ {\r
+ handleTypes = handleTypes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkExportFenceCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkExportFenceCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( ExportFenceCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( handleTypes == rhs.handleTypes );\r
+ }\r
+\r
+ bool operator!=( ExportFenceCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExportFenceCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ExternalFenceHandleTypeFlags handleTypes;\r
+ };\r
+ static_assert( sizeof( ExportFenceCreateInfo ) == sizeof( VkExportFenceCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using ExportFenceCreateInfoKHR = ExportFenceCreateInfo;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct FenceGetWin32HandleInfoKHR\r
+ {\r
+ FenceGetWin32HandleInfoKHR( Fence fence_ = Fence(), ExternalFenceHandleTypeFlagBits handleType_ = ExternalFenceHandleTypeFlagBits::eOpaqueFd )\r
+ : fence( fence_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ FenceGetWin32HandleInfoKHR( VkFenceGetWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FenceGetWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ FenceGetWin32HandleInfoKHR& operator=( VkFenceGetWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FenceGetWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ FenceGetWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ FenceGetWin32HandleInfoKHR& setFence( Fence fence_ )\r
+ {\r
+ fence = fence_;\r
+ return *this;\r
+ }\r
+\r
+ FenceGetWin32HandleInfoKHR& setHandleType( ExternalFenceHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkFenceGetWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkFenceGetWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( FenceGetWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( fence == rhs.fence )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( FenceGetWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eFenceGetWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Fence fence;\r
+ ExternalFenceHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( FenceGetWin32HandleInfoKHR ) == sizeof( VkFenceGetWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct FenceGetFdInfoKHR\r
+ {\r
+ FenceGetFdInfoKHR( Fence fence_ = Fence(), ExternalFenceHandleTypeFlagBits handleType_ = ExternalFenceHandleTypeFlagBits::eOpaqueFd )\r
+ : fence( fence_ )\r
+ , handleType( handleType_ )\r
+ {\r
+ }\r
+\r
+ FenceGetFdInfoKHR( VkFenceGetFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FenceGetFdInfoKHR ) );\r
+ }\r
+\r
+ FenceGetFdInfoKHR& operator=( VkFenceGetFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( FenceGetFdInfoKHR ) );\r
+ return *this;\r
+ }\r
+ FenceGetFdInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ FenceGetFdInfoKHR& setFence( Fence fence_ )\r
+ {\r
+ fence = fence_;\r
+ return *this;\r
+ }\r
+\r
+ FenceGetFdInfoKHR& setHandleType( ExternalFenceHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkFenceGetFdInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkFenceGetFdInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( FenceGetFdInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( fence == rhs.fence )\r
+ && ( handleType == rhs.handleType );\r
+ }\r
+\r
+ bool operator!=( FenceGetFdInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eFenceGetFdInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Fence fence;\r
+ ExternalFenceHandleTypeFlagBits handleType;\r
+ };\r
+ static_assert( sizeof( FenceGetFdInfoKHR ) == sizeof( VkFenceGetFdInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class ExternalFenceFeatureFlagBits\r
+ {\r
+ eExportable = VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT,\r
+ eExportableKHR = VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT,\r
+ eImportable = VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT,\r
+ eImportableKHR = VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT\r
+ };\r
+\r
+ using ExternalFenceFeatureFlags = Flags<ExternalFenceFeatureFlagBits, VkExternalFenceFeatureFlags>;\r
+\r
+ VULKAN_HPP_INLINE ExternalFenceFeatureFlags operator|( ExternalFenceFeatureFlagBits bit0, ExternalFenceFeatureFlagBits bit1 )\r
+ {\r
+ return ExternalFenceFeatureFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE ExternalFenceFeatureFlags operator~( ExternalFenceFeatureFlagBits bits )\r
+ {\r
+ return ~( ExternalFenceFeatureFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<ExternalFenceFeatureFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(ExternalFenceFeatureFlagBits::eExportable) | VkFlags(ExternalFenceFeatureFlagBits::eImportable)\r
+ };\r
+ };\r
+\r
+ using ExternalFenceFeatureFlagsKHR = ExternalFenceFeatureFlags;\r
+\r
+ struct ExternalFenceProperties\r
+ {\r
+ operator const VkExternalFenceProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkExternalFenceProperties*>(this);\r
+ }\r
+\r
+ bool operator==( ExternalFenceProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( exportFromImportedHandleTypes == rhs.exportFromImportedHandleTypes )\r
+ && ( compatibleHandleTypes == rhs.compatibleHandleTypes )\r
+ && ( externalFenceFeatures == rhs.externalFenceFeatures );\r
+ }\r
+\r
+ bool operator!=( ExternalFenceProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eExternalFenceProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ ExternalFenceHandleTypeFlags exportFromImportedHandleTypes;\r
+ ExternalFenceHandleTypeFlags compatibleHandleTypes;\r
+ ExternalFenceFeatureFlags externalFenceFeatures;\r
+ };\r
+ static_assert( sizeof( ExternalFenceProperties ) == sizeof( VkExternalFenceProperties ), "struct and wrapper have different size!" );\r
+\r
+ using ExternalFencePropertiesKHR = ExternalFenceProperties;\r
+\r
+ enum class FenceImportFlagBits\r
+ {\r
+ eTemporary = VK_FENCE_IMPORT_TEMPORARY_BIT,\r
+ eTemporaryKHR = VK_FENCE_IMPORT_TEMPORARY_BIT\r
+ };\r
+\r
+ using FenceImportFlags = Flags<FenceImportFlagBits, VkFenceImportFlags>;\r
+\r
+ VULKAN_HPP_INLINE FenceImportFlags operator|( FenceImportFlagBits bit0, FenceImportFlagBits bit1 )\r
+ {\r
+ return FenceImportFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE FenceImportFlags operator~( FenceImportFlagBits bits )\r
+ {\r
+ return ~( FenceImportFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<FenceImportFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(FenceImportFlagBits::eTemporary)\r
+ };\r
+ };\r
+\r
+ using FenceImportFlagsKHR = FenceImportFlags;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ struct ImportFenceWin32HandleInfoKHR\r
+ {\r
+ ImportFenceWin32HandleInfoKHR( Fence fence_ = Fence(), FenceImportFlags flags_ = FenceImportFlags(), ExternalFenceHandleTypeFlagBits handleType_ = ExternalFenceHandleTypeFlagBits::eOpaqueFd, HANDLE handle_ = 0, LPCWSTR name_ = 0 )\r
+ : fence( fence_ )\r
+ , flags( flags_ )\r
+ , handleType( handleType_ )\r
+ , handle( handle_ )\r
+ , name( name_ )\r
+ {\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR( VkImportFenceWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportFenceWin32HandleInfoKHR ) );\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR& operator=( VkImportFenceWin32HandleInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportFenceWin32HandleInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImportFenceWin32HandleInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR& setFence( Fence fence_ )\r
+ {\r
+ fence = fence_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR& setFlags( FenceImportFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR& setHandleType( ExternalFenceHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR& setHandle( HANDLE handle_ )\r
+ {\r
+ handle = handle_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceWin32HandleInfoKHR& setName( LPCWSTR name_ )\r
+ {\r
+ name = name_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportFenceWin32HandleInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportFenceWin32HandleInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImportFenceWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( fence == rhs.fence )\r
+ && ( flags == rhs.flags )\r
+ && ( handleType == rhs.handleType )\r
+ && ( handle == rhs.handle )\r
+ && ( name == rhs.name );\r
+ }\r
+\r
+ bool operator!=( ImportFenceWin32HandleInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportFenceWin32HandleInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Fence fence;\r
+ FenceImportFlags flags;\r
+ ExternalFenceHandleTypeFlagBits handleType;\r
+ HANDLE handle;\r
+ LPCWSTR name;\r
+ };\r
+ static_assert( sizeof( ImportFenceWin32HandleInfoKHR ) == sizeof( VkImportFenceWin32HandleInfoKHR ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ struct ImportFenceFdInfoKHR\r
+ {\r
+ ImportFenceFdInfoKHR( Fence fence_ = Fence(), FenceImportFlags flags_ = FenceImportFlags(), ExternalFenceHandleTypeFlagBits handleType_ = ExternalFenceHandleTypeFlagBits::eOpaqueFd, int fd_ = 0 )\r
+ : fence( fence_ )\r
+ , flags( flags_ )\r
+ , handleType( handleType_ )\r
+ , fd( fd_ )\r
+ {\r
+ }\r
+\r
+ ImportFenceFdInfoKHR( VkImportFenceFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportFenceFdInfoKHR ) );\r
+ }\r
+\r
+ ImportFenceFdInfoKHR& operator=( VkImportFenceFdInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ImportFenceFdInfoKHR ) );\r
+ return *this;\r
+ }\r
+ ImportFenceFdInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceFdInfoKHR& setFence( Fence fence_ )\r
+ {\r
+ fence = fence_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceFdInfoKHR& setFlags( FenceImportFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceFdInfoKHR& setHandleType( ExternalFenceHandleTypeFlagBits handleType_ )\r
+ {\r
+ handleType = handleType_;\r
+ return *this;\r
+ }\r
+\r
+ ImportFenceFdInfoKHR& setFd( int fd_ )\r
+ {\r
+ fd = fd_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkImportFenceFdInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkImportFenceFdInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( ImportFenceFdInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( fence == rhs.fence )\r
+ && ( flags == rhs.flags )\r
+ && ( handleType == rhs.handleType )\r
+ && ( fd == rhs.fd );\r
+ }\r
+\r
+ bool operator!=( ImportFenceFdInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eImportFenceFdInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Fence fence;\r
+ FenceImportFlags flags;\r
+ ExternalFenceHandleTypeFlagBits handleType;\r
+ int fd;\r
+ };\r
+ static_assert( sizeof( ImportFenceFdInfoKHR ) == sizeof( VkImportFenceFdInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class SurfaceCounterFlagBitsEXT\r
+ {\r
+ eVblank = VK_SURFACE_COUNTER_VBLANK_EXT\r
+ };\r
+\r
+ using SurfaceCounterFlagsEXT = Flags<SurfaceCounterFlagBitsEXT, VkSurfaceCounterFlagsEXT>;\r
+\r
+ VULKAN_HPP_INLINE SurfaceCounterFlagsEXT operator|( SurfaceCounterFlagBitsEXT bit0, SurfaceCounterFlagBitsEXT bit1 )\r
+ {\r
+ return SurfaceCounterFlagsEXT( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SurfaceCounterFlagsEXT operator~( SurfaceCounterFlagBitsEXT bits )\r
+ {\r
+ return ~( SurfaceCounterFlagsEXT( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SurfaceCounterFlagBitsEXT>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SurfaceCounterFlagBitsEXT::eVblank)\r
+ };\r
+ };\r
+\r
+ struct SurfaceCapabilities2EXT\r
+ {\r
+ operator const VkSurfaceCapabilities2EXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkSurfaceCapabilities2EXT*>(this);\r
+ }\r
+\r
+ bool operator==( SurfaceCapabilities2EXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( minImageCount == rhs.minImageCount )\r
+ && ( maxImageCount == rhs.maxImageCount )\r
+ && ( currentExtent == rhs.currentExtent )\r
+ && ( minImageExtent == rhs.minImageExtent )\r
+ && ( maxImageExtent == rhs.maxImageExtent )\r
+ && ( maxImageArrayLayers == rhs.maxImageArrayLayers )\r
+ && ( supportedTransforms == rhs.supportedTransforms )\r
+ && ( currentTransform == rhs.currentTransform )\r
+ && ( supportedCompositeAlpha == rhs.supportedCompositeAlpha )\r
+ && ( supportedUsageFlags == rhs.supportedUsageFlags )\r
+ && ( supportedSurfaceCounters == rhs.supportedSurfaceCounters );\r
+ }\r
+\r
+ bool operator!=( SurfaceCapabilities2EXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSurfaceCapabilities2EXT;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t minImageCount;\r
+ uint32_t maxImageCount;\r
+ Extent2D currentExtent;\r
+ Extent2D minImageExtent;\r
+ Extent2D maxImageExtent;\r
+ uint32_t maxImageArrayLayers;\r
+ SurfaceTransformFlagsKHR supportedTransforms;\r
+ SurfaceTransformFlagBitsKHR currentTransform;\r
+ CompositeAlphaFlagsKHR supportedCompositeAlpha;\r
+ ImageUsageFlags supportedUsageFlags;\r
+ SurfaceCounterFlagsEXT supportedSurfaceCounters;\r
+ };\r
+ static_assert( sizeof( SurfaceCapabilities2EXT ) == sizeof( VkSurfaceCapabilities2EXT ), "struct and wrapper have different size!" );\r
+\r
+ struct SwapchainCounterCreateInfoEXT\r
+ {\r
+ SwapchainCounterCreateInfoEXT( SurfaceCounterFlagsEXT surfaceCounters_ = SurfaceCounterFlagsEXT() )\r
+ : surfaceCounters( surfaceCounters_ )\r
+ {\r
+ }\r
+\r
+ SwapchainCounterCreateInfoEXT( VkSwapchainCounterCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SwapchainCounterCreateInfoEXT ) );\r
+ }\r
+\r
+ SwapchainCounterCreateInfoEXT& operator=( VkSwapchainCounterCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SwapchainCounterCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ SwapchainCounterCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCounterCreateInfoEXT& setSurfaceCounters( SurfaceCounterFlagsEXT surfaceCounters_ )\r
+ {\r
+ surfaceCounters = surfaceCounters_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSwapchainCounterCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkSwapchainCounterCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( SwapchainCounterCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( surfaceCounters == rhs.surfaceCounters );\r
+ }\r
+\r
+ bool operator!=( SwapchainCounterCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSwapchainCounterCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SurfaceCounterFlagsEXT surfaceCounters;\r
+ };\r
+ static_assert( sizeof( SwapchainCounterCreateInfoEXT ) == sizeof( VkSwapchainCounterCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class DisplayPowerStateEXT\r
+ {\r
+ eOff = VK_DISPLAY_POWER_STATE_OFF_EXT,\r
+ eSuspend = VK_DISPLAY_POWER_STATE_SUSPEND_EXT,\r
+ eOn = VK_DISPLAY_POWER_STATE_ON_EXT\r
+ };\r
+\r
+ struct DisplayPowerInfoEXT\r
+ {\r
+ DisplayPowerInfoEXT( DisplayPowerStateEXT powerState_ = DisplayPowerStateEXT::eOff )\r
+ : powerState( powerState_ )\r
+ {\r
+ }\r
+\r
+ DisplayPowerInfoEXT( VkDisplayPowerInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayPowerInfoEXT ) );\r
+ }\r
+\r
+ DisplayPowerInfoEXT& operator=( VkDisplayPowerInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayPowerInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DisplayPowerInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayPowerInfoEXT& setPowerState( DisplayPowerStateEXT powerState_ )\r
+ {\r
+ powerState = powerState_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDisplayPowerInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayPowerInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayPowerInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( powerState == rhs.powerState );\r
+ }\r
+\r
+ bool operator!=( DisplayPowerInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDisplayPowerInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DisplayPowerStateEXT powerState;\r
+ };\r
+ static_assert( sizeof( DisplayPowerInfoEXT ) == sizeof( VkDisplayPowerInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class DeviceEventTypeEXT\r
+ {\r
+ eDisplayHotplug = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT\r
+ };\r
+\r
+ struct DeviceEventInfoEXT\r
+ {\r
+ DeviceEventInfoEXT( DeviceEventTypeEXT deviceEvent_ = DeviceEventTypeEXT::eDisplayHotplug )\r
+ : deviceEvent( deviceEvent_ )\r
+ {\r
+ }\r
+\r
+ DeviceEventInfoEXT( VkDeviceEventInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceEventInfoEXT ) );\r
+ }\r
+\r
+ DeviceEventInfoEXT& operator=( VkDeviceEventInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceEventInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DeviceEventInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceEventInfoEXT& setDeviceEvent( DeviceEventTypeEXT deviceEvent_ )\r
+ {\r
+ deviceEvent = deviceEvent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceEventInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceEventInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceEventInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( deviceEvent == rhs.deviceEvent );\r
+ }\r
+\r
+ bool operator!=( DeviceEventInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceEventInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceEventTypeEXT deviceEvent;\r
+ };\r
+ static_assert( sizeof( DeviceEventInfoEXT ) == sizeof( VkDeviceEventInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class DisplayEventTypeEXT\r
+ {\r
+ eFirstPixelOut = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT\r
+ };\r
+\r
+ struct DisplayEventInfoEXT\r
+ {\r
+ DisplayEventInfoEXT( DisplayEventTypeEXT displayEvent_ = DisplayEventTypeEXT::eFirstPixelOut )\r
+ : displayEvent( displayEvent_ )\r
+ {\r
+ }\r
+\r
+ DisplayEventInfoEXT( VkDisplayEventInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayEventInfoEXT ) );\r
+ }\r
+\r
+ DisplayEventInfoEXT& operator=( VkDisplayEventInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DisplayEventInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DisplayEventInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DisplayEventInfoEXT& setDisplayEvent( DisplayEventTypeEXT displayEvent_ )\r
+ {\r
+ displayEvent = displayEvent_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDisplayEventInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDisplayEventInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DisplayEventInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( displayEvent == rhs.displayEvent );\r
+ }\r
+\r
+ bool operator!=( DisplayEventInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDisplayEventInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DisplayEventTypeEXT displayEvent;\r
+ };\r
+ static_assert( sizeof( DisplayEventInfoEXT ) == sizeof( VkDisplayEventInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class PeerMemoryFeatureFlagBits\r
+ {\r
+ eCopySrc = VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT,\r
+ eCopySrcKHR = VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT,\r
+ eCopyDst = VK_PEER_MEMORY_FEATURE_COPY_DST_BIT,\r
+ eCopyDstKHR = VK_PEER_MEMORY_FEATURE_COPY_DST_BIT,\r
+ eGenericSrc = VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT,\r
+ eGenericSrcKHR = VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT,\r
+ eGenericDst = VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT,\r
+ eGenericDstKHR = VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT\r
+ };\r
+\r
+ using PeerMemoryFeatureFlags = Flags<PeerMemoryFeatureFlagBits, VkPeerMemoryFeatureFlags>;\r
+\r
+ VULKAN_HPP_INLINE PeerMemoryFeatureFlags operator|( PeerMemoryFeatureFlagBits bit0, PeerMemoryFeatureFlagBits bit1 )\r
+ {\r
+ return PeerMemoryFeatureFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE PeerMemoryFeatureFlags operator~( PeerMemoryFeatureFlagBits bits )\r
+ {\r
+ return ~( PeerMemoryFeatureFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<PeerMemoryFeatureFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(PeerMemoryFeatureFlagBits::eCopySrc) | VkFlags(PeerMemoryFeatureFlagBits::eCopyDst) | VkFlags(PeerMemoryFeatureFlagBits::eGenericSrc) | VkFlags(PeerMemoryFeatureFlagBits::eGenericDst)\r
+ };\r
+ };\r
+\r
+ using PeerMemoryFeatureFlagsKHR = PeerMemoryFeatureFlags;\r
+\r
+ enum class MemoryAllocateFlagBits\r
+ {\r
+ eDeviceMask = VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT,\r
+ eDeviceMaskKHR = VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT\r
+ };\r
+\r
+ using MemoryAllocateFlags = Flags<MemoryAllocateFlagBits, VkMemoryAllocateFlags>;\r
+\r
+ VULKAN_HPP_INLINE MemoryAllocateFlags operator|( MemoryAllocateFlagBits bit0, MemoryAllocateFlagBits bit1 )\r
+ {\r
+ return MemoryAllocateFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE MemoryAllocateFlags operator~( MemoryAllocateFlagBits bits )\r
+ {\r
+ return ~( MemoryAllocateFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<MemoryAllocateFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(MemoryAllocateFlagBits::eDeviceMask)\r
+ };\r
+ };\r
+\r
+ using MemoryAllocateFlagsKHR = MemoryAllocateFlags;\r
+\r
+ struct MemoryAllocateFlagsInfo\r
+ {\r
+ MemoryAllocateFlagsInfo( MemoryAllocateFlags flags_ = MemoryAllocateFlags(), uint32_t deviceMask_ = 0 )\r
+ : flags( flags_ )\r
+ , deviceMask( deviceMask_ )\r
+ {\r
+ }\r
+\r
+ MemoryAllocateFlagsInfo( VkMemoryAllocateFlagsInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryAllocateFlagsInfo ) );\r
+ }\r
+\r
+ MemoryAllocateFlagsInfo& operator=( VkMemoryAllocateFlagsInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( MemoryAllocateFlagsInfo ) );\r
+ return *this;\r
+ }\r
+ MemoryAllocateFlagsInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryAllocateFlagsInfo& setFlags( MemoryAllocateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ MemoryAllocateFlagsInfo& setDeviceMask( uint32_t deviceMask_ )\r
+ {\r
+ deviceMask = deviceMask_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkMemoryAllocateFlagsInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkMemoryAllocateFlagsInfo*>(this);\r
+ }\r
+\r
+ bool operator==( MemoryAllocateFlagsInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( deviceMask == rhs.deviceMask );\r
+ }\r
+\r
+ bool operator!=( MemoryAllocateFlagsInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eMemoryAllocateFlagsInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ MemoryAllocateFlags flags;\r
+ uint32_t deviceMask;\r
+ };\r
+ static_assert( sizeof( MemoryAllocateFlagsInfo ) == sizeof( VkMemoryAllocateFlagsInfo ), "struct and wrapper have different size!" );\r
+\r
+ using MemoryAllocateFlagsInfoKHR = MemoryAllocateFlagsInfo;\r
+\r
+ enum class DeviceGroupPresentModeFlagBitsKHR\r
+ {\r
+ eLocal = VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR,\r
+ eRemote = VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR,\r
+ eSum = VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR,\r
+ eLocalMultiDevice = VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR\r
+ };\r
+\r
+ using DeviceGroupPresentModeFlagsKHR = Flags<DeviceGroupPresentModeFlagBitsKHR, VkDeviceGroupPresentModeFlagsKHR>;\r
+\r
+ VULKAN_HPP_INLINE DeviceGroupPresentModeFlagsKHR operator|( DeviceGroupPresentModeFlagBitsKHR bit0, DeviceGroupPresentModeFlagBitsKHR bit1 )\r
+ {\r
+ return DeviceGroupPresentModeFlagsKHR( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DeviceGroupPresentModeFlagsKHR operator~( DeviceGroupPresentModeFlagBitsKHR bits )\r
+ {\r
+ return ~( DeviceGroupPresentModeFlagsKHR( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DeviceGroupPresentModeFlagBitsKHR>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DeviceGroupPresentModeFlagBitsKHR::eLocal) | VkFlags(DeviceGroupPresentModeFlagBitsKHR::eRemote) | VkFlags(DeviceGroupPresentModeFlagBitsKHR::eSum) | VkFlags(DeviceGroupPresentModeFlagBitsKHR::eLocalMultiDevice)\r
+ };\r
+ };\r
+\r
+ struct DeviceGroupPresentCapabilitiesKHR\r
+ {\r
+ operator const VkDeviceGroupPresentCapabilitiesKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupPresentCapabilitiesKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupPresentCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( memcmp( presentMask, rhs.presentMask, VK_MAX_DEVICE_GROUP_SIZE * sizeof( uint32_t ) ) == 0 )\r
+ && ( modes == rhs.modes );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupPresentCapabilitiesKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupPresentCapabilitiesKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t presentMask[VK_MAX_DEVICE_GROUP_SIZE];\r
+ DeviceGroupPresentModeFlagsKHR modes;\r
+ };\r
+ static_assert( sizeof( DeviceGroupPresentCapabilitiesKHR ) == sizeof( VkDeviceGroupPresentCapabilitiesKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct DeviceGroupPresentInfoKHR\r
+ {\r
+ DeviceGroupPresentInfoKHR( uint32_t swapchainCount_ = 0, const uint32_t* pDeviceMasks_ = nullptr, DeviceGroupPresentModeFlagBitsKHR mode_ = DeviceGroupPresentModeFlagBitsKHR::eLocal )\r
+ : swapchainCount( swapchainCount_ )\r
+ , pDeviceMasks( pDeviceMasks_ )\r
+ , mode( mode_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupPresentInfoKHR( VkDeviceGroupPresentInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupPresentInfoKHR ) );\r
+ }\r
+\r
+ DeviceGroupPresentInfoKHR& operator=( VkDeviceGroupPresentInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupPresentInfoKHR ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupPresentInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupPresentInfoKHR& setSwapchainCount( uint32_t swapchainCount_ )\r
+ {\r
+ swapchainCount = swapchainCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupPresentInfoKHR& setPDeviceMasks( const uint32_t* pDeviceMasks_ )\r
+ {\r
+ pDeviceMasks = pDeviceMasks_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupPresentInfoKHR& setMode( DeviceGroupPresentModeFlagBitsKHR mode_ )\r
+ {\r
+ mode = mode_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupPresentInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupPresentInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupPresentInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( swapchainCount == rhs.swapchainCount )\r
+ && ( pDeviceMasks == rhs.pDeviceMasks )\r
+ && ( mode == rhs.mode );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupPresentInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupPresentInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t swapchainCount;\r
+ const uint32_t* pDeviceMasks;\r
+ DeviceGroupPresentModeFlagBitsKHR mode;\r
+ };\r
+ static_assert( sizeof( DeviceGroupPresentInfoKHR ) == sizeof( VkDeviceGroupPresentInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ struct DeviceGroupSwapchainCreateInfoKHR\r
+ {\r
+ DeviceGroupSwapchainCreateInfoKHR( DeviceGroupPresentModeFlagsKHR modes_ = DeviceGroupPresentModeFlagsKHR() )\r
+ : modes( modes_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupSwapchainCreateInfoKHR( VkDeviceGroupSwapchainCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupSwapchainCreateInfoKHR ) );\r
+ }\r
+\r
+ DeviceGroupSwapchainCreateInfoKHR& operator=( VkDeviceGroupSwapchainCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupSwapchainCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupSwapchainCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupSwapchainCreateInfoKHR& setModes( DeviceGroupPresentModeFlagsKHR modes_ )\r
+ {\r
+ modes = modes_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupSwapchainCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupSwapchainCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupSwapchainCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( modes == rhs.modes );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupSwapchainCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupSwapchainCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DeviceGroupPresentModeFlagsKHR modes;\r
+ };\r
+ static_assert( sizeof( DeviceGroupSwapchainCreateInfoKHR ) == sizeof( VkDeviceGroupSwapchainCreateInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class SwapchainCreateFlagBitsKHR\r
+ {\r
+ eSplitInstanceBindRegions = VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR,\r
+ eProtected = VK_SWAPCHAIN_CREATE_PROTECTED_BIT_KHR\r
+ };\r
+\r
+ using SwapchainCreateFlagsKHR = Flags<SwapchainCreateFlagBitsKHR, VkSwapchainCreateFlagsKHR>;\r
+\r
+ VULKAN_HPP_INLINE SwapchainCreateFlagsKHR operator|( SwapchainCreateFlagBitsKHR bit0, SwapchainCreateFlagBitsKHR bit1 )\r
+ {\r
+ return SwapchainCreateFlagsKHR( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SwapchainCreateFlagsKHR operator~( SwapchainCreateFlagBitsKHR bits )\r
+ {\r
+ return ~( SwapchainCreateFlagsKHR( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SwapchainCreateFlagBitsKHR>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SwapchainCreateFlagBitsKHR::eSplitInstanceBindRegions) | VkFlags(SwapchainCreateFlagBitsKHR::eProtected)\r
+ };\r
+ };\r
+\r
+ struct SwapchainCreateInfoKHR\r
+ {\r
+ SwapchainCreateInfoKHR( SwapchainCreateFlagsKHR flags_ = SwapchainCreateFlagsKHR(), SurfaceKHR surface_ = SurfaceKHR(), uint32_t minImageCount_ = 0, Format imageFormat_ = Format::eUndefined, ColorSpaceKHR imageColorSpace_ = ColorSpaceKHR::eSrgbNonlinear, Extent2D imageExtent_ = Extent2D(), uint32_t imageArrayLayers_ = 0, ImageUsageFlags imageUsage_ = ImageUsageFlags(), SharingMode imageSharingMode_ = SharingMode::eExclusive, uint32_t queueFamilyIndexCount_ = 0, const uint32_t* pQueueFamilyIndices_ = nullptr, SurfaceTransformFlagBitsKHR preTransform_ = SurfaceTransformFlagBitsKHR::eIdentity, CompositeAlphaFlagBitsKHR compositeAlpha_ = CompositeAlphaFlagBitsKHR::eOpaque, PresentModeKHR presentMode_ = PresentModeKHR::eImmediate, Bool32 clipped_ = 0, SwapchainKHR oldSwapchain_ = SwapchainKHR() )\r
+ : flags( flags_ )\r
+ , surface( surface_ )\r
+ , minImageCount( minImageCount_ )\r
+ , imageFormat( imageFormat_ )\r
+ , imageColorSpace( imageColorSpace_ )\r
+ , imageExtent( imageExtent_ )\r
+ , imageArrayLayers( imageArrayLayers_ )\r
+ , imageUsage( imageUsage_ )\r
+ , imageSharingMode( imageSharingMode_ )\r
+ , queueFamilyIndexCount( queueFamilyIndexCount_ )\r
+ , pQueueFamilyIndices( pQueueFamilyIndices_ )\r
+ , preTransform( preTransform_ )\r
+ , compositeAlpha( compositeAlpha_ )\r
+ , presentMode( presentMode_ )\r
+ , clipped( clipped_ )\r
+ , oldSwapchain( oldSwapchain_ )\r
+ {\r
+ }\r
+\r
+ SwapchainCreateInfoKHR( VkSwapchainCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SwapchainCreateInfoKHR ) );\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& operator=( VkSwapchainCreateInfoKHR const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SwapchainCreateInfoKHR ) );\r
+ return *this;\r
+ }\r
+ SwapchainCreateInfoKHR& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setFlags( SwapchainCreateFlagsKHR flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setSurface( SurfaceKHR surface_ )\r
+ {\r
+ surface = surface_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setMinImageCount( uint32_t minImageCount_ )\r
+ {\r
+ minImageCount = minImageCount_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setImageFormat( Format imageFormat_ )\r
+ {\r
+ imageFormat = imageFormat_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setImageColorSpace( ColorSpaceKHR imageColorSpace_ )\r
+ {\r
+ imageColorSpace = imageColorSpace_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setImageExtent( Extent2D imageExtent_ )\r
+ {\r
+ imageExtent = imageExtent_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setImageArrayLayers( uint32_t imageArrayLayers_ )\r
+ {\r
+ imageArrayLayers = imageArrayLayers_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setImageUsage( ImageUsageFlags imageUsage_ )\r
+ {\r
+ imageUsage = imageUsage_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setImageSharingMode( SharingMode imageSharingMode_ )\r
+ {\r
+ imageSharingMode = imageSharingMode_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setQueueFamilyIndexCount( uint32_t queueFamilyIndexCount_ )\r
+ {\r
+ queueFamilyIndexCount = queueFamilyIndexCount_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setPQueueFamilyIndices( const uint32_t* pQueueFamilyIndices_ )\r
+ {\r
+ pQueueFamilyIndices = pQueueFamilyIndices_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setPreTransform( SurfaceTransformFlagBitsKHR preTransform_ )\r
+ {\r
+ preTransform = preTransform_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setCompositeAlpha( CompositeAlphaFlagBitsKHR compositeAlpha_ )\r
+ {\r
+ compositeAlpha = compositeAlpha_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setPresentMode( PresentModeKHR presentMode_ )\r
+ {\r
+ presentMode = presentMode_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setClipped( Bool32 clipped_ )\r
+ {\r
+ clipped = clipped_;\r
+ return *this;\r
+ }\r
+\r
+ SwapchainCreateInfoKHR& setOldSwapchain( SwapchainKHR oldSwapchain_ )\r
+ {\r
+ oldSwapchain = oldSwapchain_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSwapchainCreateInfoKHR&() const\r
+ {\r
+ return *reinterpret_cast<const VkSwapchainCreateInfoKHR*>(this);\r
+ }\r
+\r
+ bool operator==( SwapchainCreateInfoKHR const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( surface == rhs.surface )\r
+ && ( minImageCount == rhs.minImageCount )\r
+ && ( imageFormat == rhs.imageFormat )\r
+ && ( imageColorSpace == rhs.imageColorSpace )\r
+ && ( imageExtent == rhs.imageExtent )\r
+ && ( imageArrayLayers == rhs.imageArrayLayers )\r
+ && ( imageUsage == rhs.imageUsage )\r
+ && ( imageSharingMode == rhs.imageSharingMode )\r
+ && ( queueFamilyIndexCount == rhs.queueFamilyIndexCount )\r
+ && ( pQueueFamilyIndices == rhs.pQueueFamilyIndices )\r
+ && ( preTransform == rhs.preTransform )\r
+ && ( compositeAlpha == rhs.compositeAlpha )\r
+ && ( presentMode == rhs.presentMode )\r
+ && ( clipped == rhs.clipped )\r
+ && ( oldSwapchain == rhs.oldSwapchain );\r
+ }\r
+\r
+ bool operator!=( SwapchainCreateInfoKHR const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSwapchainCreateInfoKHR;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SwapchainCreateFlagsKHR flags;\r
+ SurfaceKHR surface;\r
+ uint32_t minImageCount;\r
+ Format imageFormat;\r
+ ColorSpaceKHR imageColorSpace;\r
+ Extent2D imageExtent;\r
+ uint32_t imageArrayLayers;\r
+ ImageUsageFlags imageUsage;\r
+ SharingMode imageSharingMode;\r
+ uint32_t queueFamilyIndexCount;\r
+ const uint32_t* pQueueFamilyIndices;\r
+ SurfaceTransformFlagBitsKHR preTransform;\r
+ CompositeAlphaFlagBitsKHR compositeAlpha;\r
+ PresentModeKHR presentMode;\r
+ Bool32 clipped;\r
+ SwapchainKHR oldSwapchain;\r
+ };\r
+ static_assert( sizeof( SwapchainCreateInfoKHR ) == sizeof( VkSwapchainCreateInfoKHR ), "struct and wrapper have different size!" );\r
+\r
+ enum class ViewportCoordinateSwizzleNV\r
+ {\r
+ ePositiveX = VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV,\r
+ eNegativeX = VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_X_NV,\r
+ ePositiveY = VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Y_NV,\r
+ eNegativeY = VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Y_NV,\r
+ ePositiveZ = VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Z_NV,\r
+ eNegativeZ = VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Z_NV,\r
+ ePositiveW = VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_W_NV,\r
+ eNegativeW = VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV\r
+ };\r
+\r
+ struct ViewportSwizzleNV\r
+ {\r
+ ViewportSwizzleNV( ViewportCoordinateSwizzleNV x_ = ViewportCoordinateSwizzleNV::ePositiveX, ViewportCoordinateSwizzleNV y_ = ViewportCoordinateSwizzleNV::ePositiveX, ViewportCoordinateSwizzleNV z_ = ViewportCoordinateSwizzleNV::ePositiveX, ViewportCoordinateSwizzleNV w_ = ViewportCoordinateSwizzleNV::ePositiveX )\r
+ : x( x_ )\r
+ , y( y_ )\r
+ , z( z_ )\r
+ , w( w_ )\r
+ {\r
+ }\r
+\r
+ ViewportSwizzleNV( VkViewportSwizzleNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ViewportSwizzleNV ) );\r
+ }\r
+\r
+ ViewportSwizzleNV& operator=( VkViewportSwizzleNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( ViewportSwizzleNV ) );\r
+ return *this;\r
+ }\r
+ ViewportSwizzleNV& setX( ViewportCoordinateSwizzleNV x_ )\r
+ {\r
+ x = x_;\r
+ return *this;\r
+ }\r
+\r
+ ViewportSwizzleNV& setY( ViewportCoordinateSwizzleNV y_ )\r
+ {\r
+ y = y_;\r
+ return *this;\r
+ }\r
+\r
+ ViewportSwizzleNV& setZ( ViewportCoordinateSwizzleNV z_ )\r
+ {\r
+ z = z_;\r
+ return *this;\r
+ }\r
+\r
+ ViewportSwizzleNV& setW( ViewportCoordinateSwizzleNV w_ )\r
+ {\r
+ w = w_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkViewportSwizzleNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkViewportSwizzleNV*>(this);\r
+ }\r
+\r
+ bool operator==( ViewportSwizzleNV const& rhs ) const\r
+ {\r
+ return ( x == rhs.x )\r
+ && ( y == rhs.y )\r
+ && ( z == rhs.z )\r
+ && ( w == rhs.w );\r
+ }\r
+\r
+ bool operator!=( ViewportSwizzleNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ ViewportCoordinateSwizzleNV x;\r
+ ViewportCoordinateSwizzleNV y;\r
+ ViewportCoordinateSwizzleNV z;\r
+ ViewportCoordinateSwizzleNV w;\r
+ };\r
+ static_assert( sizeof( ViewportSwizzleNV ) == sizeof( VkViewportSwizzleNV ), "struct and wrapper have different size!" );\r
+\r
+ struct PipelineViewportSwizzleStateCreateInfoNV\r
+ {\r
+ PipelineViewportSwizzleStateCreateInfoNV( PipelineViewportSwizzleStateCreateFlagsNV flags_ = PipelineViewportSwizzleStateCreateFlagsNV(), uint32_t viewportCount_ = 0, const ViewportSwizzleNV* pViewportSwizzles_ = nullptr )\r
+ : flags( flags_ )\r
+ , viewportCount( viewportCount_ )\r
+ , pViewportSwizzles( pViewportSwizzles_ )\r
+ {\r
+ }\r
+\r
+ PipelineViewportSwizzleStateCreateInfoNV( VkPipelineViewportSwizzleStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineViewportSwizzleStateCreateInfoNV ) );\r
+ }\r
+\r
+ PipelineViewportSwizzleStateCreateInfoNV& operator=( VkPipelineViewportSwizzleStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineViewportSwizzleStateCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ PipelineViewportSwizzleStateCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportSwizzleStateCreateInfoNV& setFlags( PipelineViewportSwizzleStateCreateFlagsNV flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportSwizzleStateCreateInfoNV& setViewportCount( uint32_t viewportCount_ )\r
+ {\r
+ viewportCount = viewportCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineViewportSwizzleStateCreateInfoNV& setPViewportSwizzles( const ViewportSwizzleNV* pViewportSwizzles_ )\r
+ {\r
+ pViewportSwizzles = pViewportSwizzles_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineViewportSwizzleStateCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineViewportSwizzleStateCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineViewportSwizzleStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( viewportCount == rhs.viewportCount )\r
+ && ( pViewportSwizzles == rhs.pViewportSwizzles );\r
+ }\r
+\r
+ bool operator!=( PipelineViewportSwizzleStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineViewportSwizzleStateCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineViewportSwizzleStateCreateFlagsNV flags;\r
+ uint32_t viewportCount;\r
+ const ViewportSwizzleNV* pViewportSwizzles;\r
+ };\r
+ static_assert( sizeof( PipelineViewportSwizzleStateCreateInfoNV ) == sizeof( VkPipelineViewportSwizzleStateCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ enum class DiscardRectangleModeEXT\r
+ {\r
+ eInclusive = VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT,\r
+ eExclusive = VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT\r
+ };\r
+\r
+ struct PipelineDiscardRectangleStateCreateInfoEXT\r
+ {\r
+ PipelineDiscardRectangleStateCreateInfoEXT( PipelineDiscardRectangleStateCreateFlagsEXT flags_ = PipelineDiscardRectangleStateCreateFlagsEXT(), DiscardRectangleModeEXT discardRectangleMode_ = DiscardRectangleModeEXT::eInclusive, uint32_t discardRectangleCount_ = 0, const Rect2D* pDiscardRectangles_ = nullptr )\r
+ : flags( flags_ )\r
+ , discardRectangleMode( discardRectangleMode_ )\r
+ , discardRectangleCount( discardRectangleCount_ )\r
+ , pDiscardRectangles( pDiscardRectangles_ )\r
+ {\r
+ }\r
+\r
+ PipelineDiscardRectangleStateCreateInfoEXT( VkPipelineDiscardRectangleStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineDiscardRectangleStateCreateInfoEXT ) );\r
+ }\r
+\r
+ PipelineDiscardRectangleStateCreateInfoEXT& operator=( VkPipelineDiscardRectangleStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineDiscardRectangleStateCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ PipelineDiscardRectangleStateCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDiscardRectangleStateCreateInfoEXT& setFlags( PipelineDiscardRectangleStateCreateFlagsEXT flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDiscardRectangleStateCreateInfoEXT& setDiscardRectangleMode( DiscardRectangleModeEXT discardRectangleMode_ )\r
+ {\r
+ discardRectangleMode = discardRectangleMode_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDiscardRectangleStateCreateInfoEXT& setDiscardRectangleCount( uint32_t discardRectangleCount_ )\r
+ {\r
+ discardRectangleCount = discardRectangleCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineDiscardRectangleStateCreateInfoEXT& setPDiscardRectangles( const Rect2D* pDiscardRectangles_ )\r
+ {\r
+ pDiscardRectangles = pDiscardRectangles_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineDiscardRectangleStateCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineDiscardRectangleStateCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineDiscardRectangleStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( discardRectangleMode == rhs.discardRectangleMode )\r
+ && ( discardRectangleCount == rhs.discardRectangleCount )\r
+ && ( pDiscardRectangles == rhs.pDiscardRectangles );\r
+ }\r
+\r
+ bool operator!=( PipelineDiscardRectangleStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineDiscardRectangleStateCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineDiscardRectangleStateCreateFlagsEXT flags;\r
+ DiscardRectangleModeEXT discardRectangleMode;\r
+ uint32_t discardRectangleCount;\r
+ const Rect2D* pDiscardRectangles;\r
+ };\r
+ static_assert( sizeof( PipelineDiscardRectangleStateCreateInfoEXT ) == sizeof( VkPipelineDiscardRectangleStateCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class SubpassDescriptionFlagBits\r
+ {\r
+ ePerViewAttributesNVX = VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX,\r
+ ePerViewPositionXOnlyNVX = VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX\r
+ };\r
+\r
+ using SubpassDescriptionFlags = Flags<SubpassDescriptionFlagBits, VkSubpassDescriptionFlags>;\r
+\r
+ VULKAN_HPP_INLINE SubpassDescriptionFlags operator|( SubpassDescriptionFlagBits bit0, SubpassDescriptionFlagBits bit1 )\r
+ {\r
+ return SubpassDescriptionFlags( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE SubpassDescriptionFlags operator~( SubpassDescriptionFlagBits bits )\r
+ {\r
+ return ~( SubpassDescriptionFlags( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<SubpassDescriptionFlagBits>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(SubpassDescriptionFlagBits::ePerViewAttributesNVX) | VkFlags(SubpassDescriptionFlagBits::ePerViewPositionXOnlyNVX)\r
+ };\r
+ };\r
+\r
+ struct SubpassDescription\r
+ {\r
+ SubpassDescription( SubpassDescriptionFlags flags_ = SubpassDescriptionFlags(), PipelineBindPoint pipelineBindPoint_ = PipelineBindPoint::eGraphics, uint32_t inputAttachmentCount_ = 0, const AttachmentReference* pInputAttachments_ = nullptr, uint32_t colorAttachmentCount_ = 0, const AttachmentReference* pColorAttachments_ = nullptr, const AttachmentReference* pResolveAttachments_ = nullptr, const AttachmentReference* pDepthStencilAttachment_ = nullptr, uint32_t preserveAttachmentCount_ = 0, const uint32_t* pPreserveAttachments_ = nullptr )\r
+ : flags( flags_ )\r
+ , pipelineBindPoint( pipelineBindPoint_ )\r
+ , inputAttachmentCount( inputAttachmentCount_ )\r
+ , pInputAttachments( pInputAttachments_ )\r
+ , colorAttachmentCount( colorAttachmentCount_ )\r
+ , pColorAttachments( pColorAttachments_ )\r
+ , pResolveAttachments( pResolveAttachments_ )\r
+ , pDepthStencilAttachment( pDepthStencilAttachment_ )\r
+ , preserveAttachmentCount( preserveAttachmentCount_ )\r
+ , pPreserveAttachments( pPreserveAttachments_ )\r
+ {\r
+ }\r
+\r
+ SubpassDescription( VkSubpassDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubpassDescription ) );\r
+ }\r
+\r
+ SubpassDescription& operator=( VkSubpassDescription const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubpassDescription ) );\r
+ return *this;\r
+ }\r
+ SubpassDescription& setFlags( SubpassDescriptionFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPipelineBindPoint( PipelineBindPoint pipelineBindPoint_ )\r
+ {\r
+ pipelineBindPoint = pipelineBindPoint_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setInputAttachmentCount( uint32_t inputAttachmentCount_ )\r
+ {\r
+ inputAttachmentCount = inputAttachmentCount_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPInputAttachments( const AttachmentReference* pInputAttachments_ )\r
+ {\r
+ pInputAttachments = pInputAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setColorAttachmentCount( uint32_t colorAttachmentCount_ )\r
+ {\r
+ colorAttachmentCount = colorAttachmentCount_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPColorAttachments( const AttachmentReference* pColorAttachments_ )\r
+ {\r
+ pColorAttachments = pColorAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPResolveAttachments( const AttachmentReference* pResolveAttachments_ )\r
+ {\r
+ pResolveAttachments = pResolveAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPDepthStencilAttachment( const AttachmentReference* pDepthStencilAttachment_ )\r
+ {\r
+ pDepthStencilAttachment = pDepthStencilAttachment_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPreserveAttachmentCount( uint32_t preserveAttachmentCount_ )\r
+ {\r
+ preserveAttachmentCount = preserveAttachmentCount_;\r
+ return *this;\r
+ }\r
+\r
+ SubpassDescription& setPPreserveAttachments( const uint32_t* pPreserveAttachments_ )\r
+ {\r
+ pPreserveAttachments = pPreserveAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSubpassDescription&() const\r
+ {\r
+ return *reinterpret_cast<const VkSubpassDescription*>(this);\r
+ }\r
+\r
+ bool operator==( SubpassDescription const& rhs ) const\r
+ {\r
+ return ( flags == rhs.flags )\r
+ && ( pipelineBindPoint == rhs.pipelineBindPoint )\r
+ && ( inputAttachmentCount == rhs.inputAttachmentCount )\r
+ && ( pInputAttachments == rhs.pInputAttachments )\r
+ && ( colorAttachmentCount == rhs.colorAttachmentCount )\r
+ && ( pColorAttachments == rhs.pColorAttachments )\r
+ && ( pResolveAttachments == rhs.pResolveAttachments )\r
+ && ( pDepthStencilAttachment == rhs.pDepthStencilAttachment )\r
+ && ( preserveAttachmentCount == rhs.preserveAttachmentCount )\r
+ && ( pPreserveAttachments == rhs.pPreserveAttachments );\r
+ }\r
+\r
+ bool operator!=( SubpassDescription const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ SubpassDescriptionFlags flags;\r
+ PipelineBindPoint pipelineBindPoint;\r
+ uint32_t inputAttachmentCount;\r
+ const AttachmentReference* pInputAttachments;\r
+ uint32_t colorAttachmentCount;\r
+ const AttachmentReference* pColorAttachments;\r
+ const AttachmentReference* pResolveAttachments;\r
+ const AttachmentReference* pDepthStencilAttachment;\r
+ uint32_t preserveAttachmentCount;\r
+ const uint32_t* pPreserveAttachments;\r
+ };\r
+ static_assert( sizeof( SubpassDescription ) == sizeof( VkSubpassDescription ), "struct and wrapper have different size!" );\r
+\r
+ struct RenderPassCreateInfo\r
+ {\r
+ RenderPassCreateInfo( RenderPassCreateFlags flags_ = RenderPassCreateFlags(), uint32_t attachmentCount_ = 0, const AttachmentDescription* pAttachments_ = nullptr, uint32_t subpassCount_ = 0, const SubpassDescription* pSubpasses_ = nullptr, uint32_t dependencyCount_ = 0, const SubpassDependency* pDependencies_ = nullptr )\r
+ : flags( flags_ )\r
+ , attachmentCount( attachmentCount_ )\r
+ , pAttachments( pAttachments_ )\r
+ , subpassCount( subpassCount_ )\r
+ , pSubpasses( pSubpasses_ )\r
+ , dependencyCount( dependencyCount_ )\r
+ , pDependencies( pDependencies_ )\r
+ {\r
+ }\r
+\r
+ RenderPassCreateInfo( VkRenderPassCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassCreateInfo ) );\r
+ }\r
+\r
+ RenderPassCreateInfo& operator=( VkRenderPassCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( RenderPassCreateInfo ) );\r
+ return *this;\r
+ }\r
+ RenderPassCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setFlags( RenderPassCreateFlags flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setAttachmentCount( uint32_t attachmentCount_ )\r
+ {\r
+ attachmentCount = attachmentCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setPAttachments( const AttachmentDescription* pAttachments_ )\r
+ {\r
+ pAttachments = pAttachments_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setSubpassCount( uint32_t subpassCount_ )\r
+ {\r
+ subpassCount = subpassCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setPSubpasses( const SubpassDescription* pSubpasses_ )\r
+ {\r
+ pSubpasses = pSubpasses_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setDependencyCount( uint32_t dependencyCount_ )\r
+ {\r
+ dependencyCount = dependencyCount_;\r
+ return *this;\r
+ }\r
+\r
+ RenderPassCreateInfo& setPDependencies( const SubpassDependency* pDependencies_ )\r
+ {\r
+ pDependencies = pDependencies_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkRenderPassCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkRenderPassCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( RenderPassCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( attachmentCount == rhs.attachmentCount )\r
+ && ( pAttachments == rhs.pAttachments )\r
+ && ( subpassCount == rhs.subpassCount )\r
+ && ( pSubpasses == rhs.pSubpasses )\r
+ && ( dependencyCount == rhs.dependencyCount )\r
+ && ( pDependencies == rhs.pDependencies );\r
+ }\r
+\r
+ bool operator!=( RenderPassCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eRenderPassCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ RenderPassCreateFlags flags;\r
+ uint32_t attachmentCount;\r
+ const AttachmentDescription* pAttachments;\r
+ uint32_t subpassCount;\r
+ const SubpassDescription* pSubpasses;\r
+ uint32_t dependencyCount;\r
+ const SubpassDependency* pDependencies;\r
+ };\r
+ static_assert( sizeof( RenderPassCreateInfo ) == sizeof( VkRenderPassCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ enum class PointClippingBehavior\r
+ {\r
+ eAllClipPlanes = VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES,\r
+ eAllClipPlanesKHR = VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES,\r
+ eUserClipPlanesOnly = VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY,\r
+ eUserClipPlanesOnlyKHR = VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY\r
+ };\r
+\r
+ struct PhysicalDevicePointClippingProperties\r
+ {\r
+ operator const VkPhysicalDevicePointClippingProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDevicePointClippingProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDevicePointClippingProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( pointClippingBehavior == rhs.pointClippingBehavior );\r
+ }\r
+\r
+ bool operator!=( PhysicalDevicePointClippingProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDevicePointClippingProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ PointClippingBehavior pointClippingBehavior;\r
+ };\r
+ static_assert( sizeof( PhysicalDevicePointClippingProperties ) == sizeof( VkPhysicalDevicePointClippingProperties ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDevicePointClippingPropertiesKHR = PhysicalDevicePointClippingProperties;\r
+\r
+ enum class SamplerReductionModeEXT\r
+ {\r
+ eWeightedAverage = VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT,\r
+ eMin = VK_SAMPLER_REDUCTION_MODE_MIN_EXT,\r
+ eMax = VK_SAMPLER_REDUCTION_MODE_MAX_EXT\r
+ };\r
+\r
+ struct SamplerReductionModeCreateInfoEXT\r
+ {\r
+ SamplerReductionModeCreateInfoEXT( SamplerReductionModeEXT reductionMode_ = SamplerReductionModeEXT::eWeightedAverage )\r
+ : reductionMode( reductionMode_ )\r
+ {\r
+ }\r
+\r
+ SamplerReductionModeCreateInfoEXT( VkSamplerReductionModeCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerReductionModeCreateInfoEXT ) );\r
+ }\r
+\r
+ SamplerReductionModeCreateInfoEXT& operator=( VkSamplerReductionModeCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerReductionModeCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ SamplerReductionModeCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerReductionModeCreateInfoEXT& setReductionMode( SamplerReductionModeEXT reductionMode_ )\r
+ {\r
+ reductionMode = reductionMode_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSamplerReductionModeCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkSamplerReductionModeCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( SamplerReductionModeCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( reductionMode == rhs.reductionMode );\r
+ }\r
+\r
+ bool operator!=( SamplerReductionModeCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSamplerReductionModeCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ SamplerReductionModeEXT reductionMode;\r
+ };\r
+ static_assert( sizeof( SamplerReductionModeCreateInfoEXT ) == sizeof( VkSamplerReductionModeCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class TessellationDomainOrigin\r
+ {\r
+ eUpperLeft = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT,\r
+ eUpperLeftKHR = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT,\r
+ eLowerLeft = VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT,\r
+ eLowerLeftKHR = VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT\r
+ };\r
+\r
+ struct PipelineTessellationDomainOriginStateCreateInfo\r
+ {\r
+ PipelineTessellationDomainOriginStateCreateInfo( TessellationDomainOrigin domainOrigin_ = TessellationDomainOrigin::eUpperLeft )\r
+ : domainOrigin( domainOrigin_ )\r
+ {\r
+ }\r
+\r
+ PipelineTessellationDomainOriginStateCreateInfo( VkPipelineTessellationDomainOriginStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineTessellationDomainOriginStateCreateInfo ) );\r
+ }\r
+\r
+ PipelineTessellationDomainOriginStateCreateInfo& operator=( VkPipelineTessellationDomainOriginStateCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineTessellationDomainOriginStateCreateInfo ) );\r
+ return *this;\r
+ }\r
+ PipelineTessellationDomainOriginStateCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineTessellationDomainOriginStateCreateInfo& setDomainOrigin( TessellationDomainOrigin domainOrigin_ )\r
+ {\r
+ domainOrigin = domainOrigin_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineTessellationDomainOriginStateCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineTessellationDomainOriginStateCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineTessellationDomainOriginStateCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( domainOrigin == rhs.domainOrigin );\r
+ }\r
+\r
+ bool operator!=( PipelineTessellationDomainOriginStateCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineTessellationDomainOriginStateCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ TessellationDomainOrigin domainOrigin;\r
+ };\r
+ static_assert( sizeof( PipelineTessellationDomainOriginStateCreateInfo ) == sizeof( VkPipelineTessellationDomainOriginStateCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using PipelineTessellationDomainOriginStateCreateInfoKHR = PipelineTessellationDomainOriginStateCreateInfo;\r
+\r
+ enum class SamplerYcbcrModelConversion\r
+ {\r
+ eRgbIdentity = VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY,\r
+ eRgbIdentityKHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY,\r
+ eYcbcrIdentity = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY,\r
+ eYcbcrIdentityKHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY,\r
+ eYcbcr709 = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709,\r
+ eYcbcr709KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709,\r
+ eYcbcr601 = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601,\r
+ eYcbcr601KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601,\r
+ eYcbcr2020 = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020,\r
+ eYcbcr2020KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020\r
+ };\r
+\r
+ enum class SamplerYcbcrRange\r
+ {\r
+ eItuFull = VK_SAMPLER_YCBCR_RANGE_ITU_FULL,\r
+ eItuFullKHR = VK_SAMPLER_YCBCR_RANGE_ITU_FULL,\r
+ eItuNarrow = VK_SAMPLER_YCBCR_RANGE_ITU_NARROW,\r
+ eItuNarrowKHR = VK_SAMPLER_YCBCR_RANGE_ITU_NARROW\r
+ };\r
+\r
+ enum class ChromaLocation\r
+ {\r
+ eCositedEven = VK_CHROMA_LOCATION_COSITED_EVEN,\r
+ eCositedEvenKHR = VK_CHROMA_LOCATION_COSITED_EVEN,\r
+ eMidpoint = VK_CHROMA_LOCATION_MIDPOINT,\r
+ eMidpointKHR = VK_CHROMA_LOCATION_MIDPOINT\r
+ };\r
+\r
+ struct SamplerYcbcrConversionCreateInfo\r
+ {\r
+ SamplerYcbcrConversionCreateInfo( Format format_ = Format::eUndefined, SamplerYcbcrModelConversion ycbcrModel_ = SamplerYcbcrModelConversion::eRgbIdentity, SamplerYcbcrRange ycbcrRange_ = SamplerYcbcrRange::eItuFull, ComponentMapping components_ = ComponentMapping(), ChromaLocation xChromaOffset_ = ChromaLocation::eCositedEven, ChromaLocation yChromaOffset_ = ChromaLocation::eCositedEven, Filter chromaFilter_ = Filter::eNearest, Bool32 forceExplicitReconstruction_ = 0 )\r
+ : format( format_ )\r
+ , ycbcrModel( ycbcrModel_ )\r
+ , ycbcrRange( ycbcrRange_ )\r
+ , components( components_ )\r
+ , xChromaOffset( xChromaOffset_ )\r
+ , yChromaOffset( yChromaOffset_ )\r
+ , chromaFilter( chromaFilter_ )\r
+ , forceExplicitReconstruction( forceExplicitReconstruction_ )\r
+ {\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo( VkSamplerYcbcrConversionCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerYcbcrConversionCreateInfo ) );\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& operator=( VkSamplerYcbcrConversionCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SamplerYcbcrConversionCreateInfo ) );\r
+ return *this;\r
+ }\r
+ SamplerYcbcrConversionCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setFormat( Format format_ )\r
+ {\r
+ format = format_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setYcbcrModel( SamplerYcbcrModelConversion ycbcrModel_ )\r
+ {\r
+ ycbcrModel = ycbcrModel_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setYcbcrRange( SamplerYcbcrRange ycbcrRange_ )\r
+ {\r
+ ycbcrRange = ycbcrRange_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setComponents( ComponentMapping components_ )\r
+ {\r
+ components = components_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setXChromaOffset( ChromaLocation xChromaOffset_ )\r
+ {\r
+ xChromaOffset = xChromaOffset_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setYChromaOffset( ChromaLocation yChromaOffset_ )\r
+ {\r
+ yChromaOffset = yChromaOffset_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setChromaFilter( Filter chromaFilter_ )\r
+ {\r
+ chromaFilter = chromaFilter_;\r
+ return *this;\r
+ }\r
+\r
+ SamplerYcbcrConversionCreateInfo& setForceExplicitReconstruction( Bool32 forceExplicitReconstruction_ )\r
+ {\r
+ forceExplicitReconstruction = forceExplicitReconstruction_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSamplerYcbcrConversionCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SamplerYcbcrConversionCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( format == rhs.format )\r
+ && ( ycbcrModel == rhs.ycbcrModel )\r
+ && ( ycbcrRange == rhs.ycbcrRange )\r
+ && ( components == rhs.components )\r
+ && ( xChromaOffset == rhs.xChromaOffset )\r
+ && ( yChromaOffset == rhs.yChromaOffset )\r
+ && ( chromaFilter == rhs.chromaFilter )\r
+ && ( forceExplicitReconstruction == rhs.forceExplicitReconstruction );\r
+ }\r
+\r
+ bool operator!=( SamplerYcbcrConversionCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSamplerYcbcrConversionCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Format format;\r
+ SamplerYcbcrModelConversion ycbcrModel;\r
+ SamplerYcbcrRange ycbcrRange;\r
+ ComponentMapping components;\r
+ ChromaLocation xChromaOffset;\r
+ ChromaLocation yChromaOffset;\r
+ Filter chromaFilter;\r
+ Bool32 forceExplicitReconstruction;\r
+ };\r
+ static_assert( sizeof( SamplerYcbcrConversionCreateInfo ) == sizeof( VkSamplerYcbcrConversionCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using SamplerYcbcrConversionCreateInfoKHR = SamplerYcbcrConversionCreateInfo;\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ struct AndroidHardwareBufferFormatPropertiesANDROID\r
+ {\r
+ operator const VkAndroidHardwareBufferFormatPropertiesANDROID&() const\r
+ {\r
+ return *reinterpret_cast<const VkAndroidHardwareBufferFormatPropertiesANDROID*>(this);\r
+ }\r
+\r
+ bool operator==( AndroidHardwareBufferFormatPropertiesANDROID const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( format == rhs.format )\r
+ && ( externalFormat == rhs.externalFormat )\r
+ && ( formatFeatures == rhs.formatFeatures )\r
+ && ( samplerYcbcrConversionComponents == rhs.samplerYcbcrConversionComponents )\r
+ && ( suggestedYcbcrModel == rhs.suggestedYcbcrModel )\r
+ && ( suggestedYcbcrRange == rhs.suggestedYcbcrRange )\r
+ && ( suggestedXChromaOffset == rhs.suggestedXChromaOffset )\r
+ && ( suggestedYChromaOffset == rhs.suggestedYChromaOffset );\r
+ }\r
+\r
+ bool operator!=( AndroidHardwareBufferFormatPropertiesANDROID const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eAndroidHardwareBufferFormatPropertiesANDROID;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ Format format;\r
+ uint64_t externalFormat;\r
+ FormatFeatureFlags formatFeatures;\r
+ ComponentMapping samplerYcbcrConversionComponents;\r
+ SamplerYcbcrModelConversion suggestedYcbcrModel;\r
+ SamplerYcbcrRange suggestedYcbcrRange;\r
+ ChromaLocation suggestedXChromaOffset;\r
+ ChromaLocation suggestedYChromaOffset;\r
+ };\r
+ static_assert( sizeof( AndroidHardwareBufferFormatPropertiesANDROID ) == sizeof( VkAndroidHardwareBufferFormatPropertiesANDROID ), "struct and wrapper have different size!" );\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+ enum class BlendOverlapEXT\r
+ {\r
+ eUncorrelated = VK_BLEND_OVERLAP_UNCORRELATED_EXT,\r
+ eDisjoint = VK_BLEND_OVERLAP_DISJOINT_EXT,\r
+ eConjoint = VK_BLEND_OVERLAP_CONJOINT_EXT\r
+ };\r
+\r
+ struct PipelineColorBlendAdvancedStateCreateInfoEXT\r
+ {\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT( Bool32 srcPremultiplied_ = 0, Bool32 dstPremultiplied_ = 0, BlendOverlapEXT blendOverlap_ = BlendOverlapEXT::eUncorrelated )\r
+ : srcPremultiplied( srcPremultiplied_ )\r
+ , dstPremultiplied( dstPremultiplied_ )\r
+ , blendOverlap( blendOverlap_ )\r
+ {\r
+ }\r
+\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT( VkPipelineColorBlendAdvancedStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineColorBlendAdvancedStateCreateInfoEXT ) );\r
+ }\r
+\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT& operator=( VkPipelineColorBlendAdvancedStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineColorBlendAdvancedStateCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT& setSrcPremultiplied( Bool32 srcPremultiplied_ )\r
+ {\r
+ srcPremultiplied = srcPremultiplied_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT& setDstPremultiplied( Bool32 dstPremultiplied_ )\r
+ {\r
+ dstPremultiplied = dstPremultiplied_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineColorBlendAdvancedStateCreateInfoEXT& setBlendOverlap( BlendOverlapEXT blendOverlap_ )\r
+ {\r
+ blendOverlap = blendOverlap_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineColorBlendAdvancedStateCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineColorBlendAdvancedStateCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineColorBlendAdvancedStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( srcPremultiplied == rhs.srcPremultiplied )\r
+ && ( dstPremultiplied == rhs.dstPremultiplied )\r
+ && ( blendOverlap == rhs.blendOverlap );\r
+ }\r
+\r
+ bool operator!=( PipelineColorBlendAdvancedStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineColorBlendAdvancedStateCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ Bool32 srcPremultiplied;\r
+ Bool32 dstPremultiplied;\r
+ BlendOverlapEXT blendOverlap;\r
+ };\r
+ static_assert( sizeof( PipelineColorBlendAdvancedStateCreateInfoEXT ) == sizeof( VkPipelineColorBlendAdvancedStateCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class CoverageModulationModeNV\r
+ {\r
+ eNone = VK_COVERAGE_MODULATION_MODE_NONE_NV,\r
+ eRgb = VK_COVERAGE_MODULATION_MODE_RGB_NV,\r
+ eAlpha = VK_COVERAGE_MODULATION_MODE_ALPHA_NV,\r
+ eRgba = VK_COVERAGE_MODULATION_MODE_RGBA_NV\r
+ };\r
+\r
+ struct PipelineCoverageModulationStateCreateInfoNV\r
+ {\r
+ PipelineCoverageModulationStateCreateInfoNV( PipelineCoverageModulationStateCreateFlagsNV flags_ = PipelineCoverageModulationStateCreateFlagsNV(), CoverageModulationModeNV coverageModulationMode_ = CoverageModulationModeNV::eNone, Bool32 coverageModulationTableEnable_ = 0, uint32_t coverageModulationTableCount_ = 0, const float* pCoverageModulationTable_ = nullptr )\r
+ : flags( flags_ )\r
+ , coverageModulationMode( coverageModulationMode_ )\r
+ , coverageModulationTableEnable( coverageModulationTableEnable_ )\r
+ , coverageModulationTableCount( coverageModulationTableCount_ )\r
+ , pCoverageModulationTable( pCoverageModulationTable_ )\r
+ {\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV( VkPipelineCoverageModulationStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineCoverageModulationStateCreateInfoNV ) );\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV& operator=( VkPipelineCoverageModulationStateCreateInfoNV const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineCoverageModulationStateCreateInfoNV ) );\r
+ return *this;\r
+ }\r
+ PipelineCoverageModulationStateCreateInfoNV& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV& setFlags( PipelineCoverageModulationStateCreateFlagsNV flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV& setCoverageModulationMode( CoverageModulationModeNV coverageModulationMode_ )\r
+ {\r
+ coverageModulationMode = coverageModulationMode_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV& setCoverageModulationTableEnable( Bool32 coverageModulationTableEnable_ )\r
+ {\r
+ coverageModulationTableEnable = coverageModulationTableEnable_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV& setCoverageModulationTableCount( uint32_t coverageModulationTableCount_ )\r
+ {\r
+ coverageModulationTableCount = coverageModulationTableCount_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineCoverageModulationStateCreateInfoNV& setPCoverageModulationTable( const float* pCoverageModulationTable_ )\r
+ {\r
+ pCoverageModulationTable = pCoverageModulationTable_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineCoverageModulationStateCreateInfoNV&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineCoverageModulationStateCreateInfoNV*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineCoverageModulationStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( coverageModulationMode == rhs.coverageModulationMode )\r
+ && ( coverageModulationTableEnable == rhs.coverageModulationTableEnable )\r
+ && ( coverageModulationTableCount == rhs.coverageModulationTableCount )\r
+ && ( pCoverageModulationTable == rhs.pCoverageModulationTable );\r
+ }\r
+\r
+ bool operator!=( PipelineCoverageModulationStateCreateInfoNV const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineCoverageModulationStateCreateInfoNV;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineCoverageModulationStateCreateFlagsNV flags;\r
+ CoverageModulationModeNV coverageModulationMode;\r
+ Bool32 coverageModulationTableEnable;\r
+ uint32_t coverageModulationTableCount;\r
+ const float* pCoverageModulationTable;\r
+ };\r
+ static_assert( sizeof( PipelineCoverageModulationStateCreateInfoNV ) == sizeof( VkPipelineCoverageModulationStateCreateInfoNV ), "struct and wrapper have different size!" );\r
+\r
+ enum class ValidationCacheHeaderVersionEXT\r
+ {\r
+ eOne = VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT\r
+ };\r
+\r
+ enum class ShaderInfoTypeAMD\r
+ {\r
+ eStatistics = VK_SHADER_INFO_TYPE_STATISTICS_AMD,\r
+ eBinary = VK_SHADER_INFO_TYPE_BINARY_AMD,\r
+ eDisassembly = VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD\r
+ };\r
+\r
+ enum class QueueGlobalPriorityEXT\r
+ {\r
+ eLow = VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT,\r
+ eMedium = VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT,\r
+ eHigh = VK_QUEUE_GLOBAL_PRIORITY_HIGH_EXT,\r
+ eRealtime = VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT\r
+ };\r
+\r
+ struct DeviceQueueGlobalPriorityCreateInfoEXT\r
+ {\r
+ DeviceQueueGlobalPriorityCreateInfoEXT( QueueGlobalPriorityEXT globalPriority_ = QueueGlobalPriorityEXT::eLow )\r
+ : globalPriority( globalPriority_ )\r
+ {\r
+ }\r
+\r
+ DeviceQueueGlobalPriorityCreateInfoEXT( VkDeviceQueueGlobalPriorityCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceQueueGlobalPriorityCreateInfoEXT ) );\r
+ }\r
+\r
+ DeviceQueueGlobalPriorityCreateInfoEXT& operator=( VkDeviceQueueGlobalPriorityCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceQueueGlobalPriorityCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DeviceQueueGlobalPriorityCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceQueueGlobalPriorityCreateInfoEXT& setGlobalPriority( QueueGlobalPriorityEXT globalPriority_ )\r
+ {\r
+ globalPriority = globalPriority_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceQueueGlobalPriorityCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceQueueGlobalPriorityCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceQueueGlobalPriorityCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( globalPriority == rhs.globalPriority );\r
+ }\r
+\r
+ bool operator!=( DeviceQueueGlobalPriorityCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceQueueGlobalPriorityCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ QueueGlobalPriorityEXT globalPriority;\r
+ };\r
+ static_assert( sizeof( DeviceQueueGlobalPriorityCreateInfoEXT ) == sizeof( VkDeviceQueueGlobalPriorityCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class DebugUtilsMessageSeverityFlagBitsEXT\r
+ {\r
+ eVerbose = VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT,\r
+ eInfo = VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT,\r
+ eWarning = VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT,\r
+ eError = VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT\r
+ };\r
+\r
+ using DebugUtilsMessageSeverityFlagsEXT = Flags<DebugUtilsMessageSeverityFlagBitsEXT, VkDebugUtilsMessageSeverityFlagsEXT>;\r
+\r
+ VULKAN_HPP_INLINE DebugUtilsMessageSeverityFlagsEXT operator|( DebugUtilsMessageSeverityFlagBitsEXT bit0, DebugUtilsMessageSeverityFlagBitsEXT bit1 )\r
+ {\r
+ return DebugUtilsMessageSeverityFlagsEXT( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DebugUtilsMessageSeverityFlagsEXT operator~( DebugUtilsMessageSeverityFlagBitsEXT bits )\r
+ {\r
+ return ~( DebugUtilsMessageSeverityFlagsEXT( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DebugUtilsMessageSeverityFlagBitsEXT>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DebugUtilsMessageSeverityFlagBitsEXT::eVerbose) | VkFlags(DebugUtilsMessageSeverityFlagBitsEXT::eInfo) | VkFlags(DebugUtilsMessageSeverityFlagBitsEXT::eWarning) | VkFlags(DebugUtilsMessageSeverityFlagBitsEXT::eError)\r
+ };\r
+ };\r
+\r
+ enum class DebugUtilsMessageTypeFlagBitsEXT\r
+ {\r
+ eGeneral = VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT,\r
+ eValidation = VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT,\r
+ ePerformance = VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT\r
+ };\r
+\r
+ using DebugUtilsMessageTypeFlagsEXT = Flags<DebugUtilsMessageTypeFlagBitsEXT, VkDebugUtilsMessageTypeFlagsEXT>;\r
+\r
+ VULKAN_HPP_INLINE DebugUtilsMessageTypeFlagsEXT operator|( DebugUtilsMessageTypeFlagBitsEXT bit0, DebugUtilsMessageTypeFlagBitsEXT bit1 )\r
+ {\r
+ return DebugUtilsMessageTypeFlagsEXT( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DebugUtilsMessageTypeFlagsEXT operator~( DebugUtilsMessageTypeFlagBitsEXT bits )\r
+ {\r
+ return ~( DebugUtilsMessageTypeFlagsEXT( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DebugUtilsMessageTypeFlagBitsEXT>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DebugUtilsMessageTypeFlagBitsEXT::eGeneral) | VkFlags(DebugUtilsMessageTypeFlagBitsEXT::eValidation) | VkFlags(DebugUtilsMessageTypeFlagBitsEXT::ePerformance)\r
+ };\r
+ };\r
+\r
+ struct DebugUtilsMessengerCreateInfoEXT\r
+ {\r
+ DebugUtilsMessengerCreateInfoEXT( DebugUtilsMessengerCreateFlagsEXT flags_ = DebugUtilsMessengerCreateFlagsEXT(), DebugUtilsMessageSeverityFlagsEXT messageSeverity_ = DebugUtilsMessageSeverityFlagsEXT(), DebugUtilsMessageTypeFlagsEXT messageType_ = DebugUtilsMessageTypeFlagsEXT(), PFN_vkDebugUtilsMessengerCallbackEXT pfnUserCallback_ = nullptr, void* pUserData_ = nullptr )\r
+ : flags( flags_ )\r
+ , messageSeverity( messageSeverity_ )\r
+ , messageType( messageType_ )\r
+ , pfnUserCallback( pfnUserCallback_ )\r
+ , pUserData( pUserData_ )\r
+ {\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT( VkDebugUtilsMessengerCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsMessengerCreateInfoEXT ) );\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT& operator=( VkDebugUtilsMessengerCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DebugUtilsMessengerCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DebugUtilsMessengerCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT& setFlags( DebugUtilsMessengerCreateFlagsEXT flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT& setMessageSeverity( DebugUtilsMessageSeverityFlagsEXT messageSeverity_ )\r
+ {\r
+ messageSeverity = messageSeverity_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT& setMessageType( DebugUtilsMessageTypeFlagsEXT messageType_ )\r
+ {\r
+ messageType = messageType_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT& setPfnUserCallback( PFN_vkDebugUtilsMessengerCallbackEXT pfnUserCallback_ )\r
+ {\r
+ pfnUserCallback = pfnUserCallback_;\r
+ return *this;\r
+ }\r
+\r
+ DebugUtilsMessengerCreateInfoEXT& setPUserData( void* pUserData_ )\r
+ {\r
+ pUserData = pUserData_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDebugUtilsMessengerCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDebugUtilsMessengerCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DebugUtilsMessengerCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( messageSeverity == rhs.messageSeverity )\r
+ && ( messageType == rhs.messageType )\r
+ && ( pfnUserCallback == rhs.pfnUserCallback )\r
+ && ( pUserData == rhs.pUserData );\r
+ }\r
+\r
+ bool operator!=( DebugUtilsMessengerCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDebugUtilsMessengerCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ DebugUtilsMessengerCreateFlagsEXT flags;\r
+ DebugUtilsMessageSeverityFlagsEXT messageSeverity;\r
+ DebugUtilsMessageTypeFlagsEXT messageType;\r
+ PFN_vkDebugUtilsMessengerCallbackEXT pfnUserCallback;\r
+ void* pUserData;\r
+ };\r
+ static_assert( sizeof( DebugUtilsMessengerCreateInfoEXT ) == sizeof( VkDebugUtilsMessengerCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class ConservativeRasterizationModeEXT\r
+ {\r
+ eDisabled = VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT,\r
+ eOverestimate = VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT,\r
+ eUnderestimate = VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT\r
+ };\r
+\r
+ struct PipelineRasterizationConservativeStateCreateInfoEXT\r
+ {\r
+ PipelineRasterizationConservativeStateCreateInfoEXT( PipelineRasterizationConservativeStateCreateFlagsEXT flags_ = PipelineRasterizationConservativeStateCreateFlagsEXT(), ConservativeRasterizationModeEXT conservativeRasterizationMode_ = ConservativeRasterizationModeEXT::eDisabled, float extraPrimitiveOverestimationSize_ = 0 )\r
+ : flags( flags_ )\r
+ , conservativeRasterizationMode( conservativeRasterizationMode_ )\r
+ , extraPrimitiveOverestimationSize( extraPrimitiveOverestimationSize_ )\r
+ {\r
+ }\r
+\r
+ PipelineRasterizationConservativeStateCreateInfoEXT( VkPipelineRasterizationConservativeStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineRasterizationConservativeStateCreateInfoEXT ) );\r
+ }\r
+\r
+ PipelineRasterizationConservativeStateCreateInfoEXT& operator=( VkPipelineRasterizationConservativeStateCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( PipelineRasterizationConservativeStateCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ PipelineRasterizationConservativeStateCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationConservativeStateCreateInfoEXT& setFlags( PipelineRasterizationConservativeStateCreateFlagsEXT flags_ )\r
+ {\r
+ flags = flags_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationConservativeStateCreateInfoEXT& setConservativeRasterizationMode( ConservativeRasterizationModeEXT conservativeRasterizationMode_ )\r
+ {\r
+ conservativeRasterizationMode = conservativeRasterizationMode_;\r
+ return *this;\r
+ }\r
+\r
+ PipelineRasterizationConservativeStateCreateInfoEXT& setExtraPrimitiveOverestimationSize( float extraPrimitiveOverestimationSize_ )\r
+ {\r
+ extraPrimitiveOverestimationSize = extraPrimitiveOverestimationSize_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkPipelineRasterizationConservativeStateCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkPipelineRasterizationConservativeStateCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( PipelineRasterizationConservativeStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( flags == rhs.flags )\r
+ && ( conservativeRasterizationMode == rhs.conservativeRasterizationMode )\r
+ && ( extraPrimitiveOverestimationSize == rhs.extraPrimitiveOverestimationSize );\r
+ }\r
+\r
+ bool operator!=( PipelineRasterizationConservativeStateCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePipelineRasterizationConservativeStateCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ PipelineRasterizationConservativeStateCreateFlagsEXT flags;\r
+ ConservativeRasterizationModeEXT conservativeRasterizationMode;\r
+ float extraPrimitiveOverestimationSize;\r
+ };\r
+ static_assert( sizeof( PipelineRasterizationConservativeStateCreateInfoEXT ) == sizeof( VkPipelineRasterizationConservativeStateCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ enum class DescriptorBindingFlagBitsEXT\r
+ {\r
+ eUpdateAfterBind = VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT,\r
+ eUpdateUnusedWhilePending = VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT,\r
+ ePartiallyBound = VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT,\r
+ eVariableDescriptorCount = VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT\r
+ };\r
+\r
+ using DescriptorBindingFlagsEXT = Flags<DescriptorBindingFlagBitsEXT, VkDescriptorBindingFlagsEXT>;\r
+\r
+ VULKAN_HPP_INLINE DescriptorBindingFlagsEXT operator|( DescriptorBindingFlagBitsEXT bit0, DescriptorBindingFlagBitsEXT bit1 )\r
+ {\r
+ return DescriptorBindingFlagsEXT( bit0 ) | bit1;\r
+ }\r
+\r
+ VULKAN_HPP_INLINE DescriptorBindingFlagsEXT operator~( DescriptorBindingFlagBitsEXT bits )\r
+ {\r
+ return ~( DescriptorBindingFlagsEXT( bits ) );\r
+ }\r
+\r
+ template <> struct FlagTraits<DescriptorBindingFlagBitsEXT>\r
+ {\r
+ enum\r
+ {\r
+ allFlags = VkFlags(DescriptorBindingFlagBitsEXT::eUpdateAfterBind) | VkFlags(DescriptorBindingFlagBitsEXT::eUpdateUnusedWhilePending) | VkFlags(DescriptorBindingFlagBitsEXT::ePartiallyBound) | VkFlags(DescriptorBindingFlagBitsEXT::eVariableDescriptorCount)\r
+ };\r
+ };\r
+\r
+ struct DescriptorSetLayoutBindingFlagsCreateInfoEXT\r
+ {\r
+ DescriptorSetLayoutBindingFlagsCreateInfoEXT( uint32_t bindingCount_ = 0, const DescriptorBindingFlagsEXT* pBindingFlags_ = nullptr )\r
+ : bindingCount( bindingCount_ )\r
+ , pBindingFlags( pBindingFlags_ )\r
+ {\r
+ }\r
+\r
+ DescriptorSetLayoutBindingFlagsCreateInfoEXT( VkDescriptorSetLayoutBindingFlagsCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetLayoutBindingFlagsCreateInfoEXT ) );\r
+ }\r
+\r
+ DescriptorSetLayoutBindingFlagsCreateInfoEXT& operator=( VkDescriptorSetLayoutBindingFlagsCreateInfoEXT const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DescriptorSetLayoutBindingFlagsCreateInfoEXT ) );\r
+ return *this;\r
+ }\r
+ DescriptorSetLayoutBindingFlagsCreateInfoEXT& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutBindingFlagsCreateInfoEXT& setBindingCount( uint32_t bindingCount_ )\r
+ {\r
+ bindingCount = bindingCount_;\r
+ return *this;\r
+ }\r
+\r
+ DescriptorSetLayoutBindingFlagsCreateInfoEXT& setPBindingFlags( const DescriptorBindingFlagsEXT* pBindingFlags_ )\r
+ {\r
+ pBindingFlags = pBindingFlags_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDescriptorSetLayoutBindingFlagsCreateInfoEXT&() const\r
+ {\r
+ return *reinterpret_cast<const VkDescriptorSetLayoutBindingFlagsCreateInfoEXT*>(this);\r
+ }\r
+\r
+ bool operator==( DescriptorSetLayoutBindingFlagsCreateInfoEXT const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( bindingCount == rhs.bindingCount )\r
+ && ( pBindingFlags == rhs.pBindingFlags );\r
+ }\r
+\r
+ bool operator!=( DescriptorSetLayoutBindingFlagsCreateInfoEXT const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDescriptorSetLayoutBindingFlagsCreateInfoEXT;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t bindingCount;\r
+ const DescriptorBindingFlagsEXT* pBindingFlags;\r
+ };\r
+ static_assert( sizeof( DescriptorSetLayoutBindingFlagsCreateInfoEXT ) == sizeof( VkDescriptorSetLayoutBindingFlagsCreateInfoEXT ), "struct and wrapper have different size!" );\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumerateInstanceVersion( uint32_t* pApiVersion, Dispatch const &d = Dispatch() );\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<uint32_t>::type enumerateInstanceVersion(Dispatch const &d = Dispatch() );\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result enumerateInstanceVersion( uint32_t* pApiVersion, Dispatch const &d)\r
+ {\r
+ return static_cast<Result>( d.vkEnumerateInstanceVersion( pApiVersion ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<uint32_t>::type enumerateInstanceVersion(Dispatch const &d )\r
+ {\r
+ uint32_t apiVersion;\r
+ Result result = static_cast<Result>( d.vkEnumerateInstanceVersion( &apiVersion ) );\r
+ return createResultValue( result, apiVersion, VULKAN_HPP_NAMESPACE_STRING"::enumerateInstanceVersion" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumerateInstanceLayerProperties( uint32_t* pPropertyCount, LayerProperties* pProperties, Dispatch const &d = Dispatch() );\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<LayerProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<LayerProperties,Allocator>>::type enumerateInstanceLayerProperties(Dispatch const &d = Dispatch() );\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result enumerateInstanceLayerProperties( uint32_t* pPropertyCount, LayerProperties* pProperties, Dispatch const &d)\r
+ {\r
+ return static_cast<Result>( d.vkEnumerateInstanceLayerProperties( pPropertyCount, reinterpret_cast<VkLayerProperties*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<LayerProperties,Allocator>>::type enumerateInstanceLayerProperties(Dispatch const &d )\r
+ {\r
+ std::vector<LayerProperties,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumerateInstanceLayerProperties( &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkEnumerateInstanceLayerProperties( &propertyCount, reinterpret_cast<VkLayerProperties*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::enumerateInstanceLayerProperties" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumerateInstanceExtensionProperties( const char* pLayerName, uint32_t* pPropertyCount, ExtensionProperties* pProperties, Dispatch const &d = Dispatch() );\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<ExtensionProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<ExtensionProperties,Allocator>>::type enumerateInstanceExtensionProperties( Optional<const std::string> layerName = nullptr, Dispatch const &d = Dispatch() );\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result enumerateInstanceExtensionProperties( const char* pLayerName, uint32_t* pPropertyCount, ExtensionProperties* pProperties, Dispatch const &d)\r
+ {\r
+ return static_cast<Result>( d.vkEnumerateInstanceExtensionProperties( pLayerName, pPropertyCount, reinterpret_cast<VkExtensionProperties*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<ExtensionProperties,Allocator>>::type enumerateInstanceExtensionProperties( Optional<const std::string> layerName, Dispatch const &d )\r
+ {\r
+ std::vector<ExtensionProperties,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumerateInstanceExtensionProperties( layerName ? layerName->c_str() : nullptr, &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkEnumerateInstanceExtensionProperties( layerName ? layerName->c_str() : nullptr, &propertyCount, reinterpret_cast<VkExtensionProperties*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::enumerateInstanceExtensionProperties" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+ // forward declarations\r
+ struct CmdProcessCommandsInfoNVX;\r
+\r
+ class CommandBuffer\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR CommandBuffer()\r
+ : m_commandBuffer(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR CommandBuffer( std::nullptr_t )\r
+ : m_commandBuffer(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT CommandBuffer( VkCommandBuffer commandBuffer )\r
+ : m_commandBuffer( commandBuffer )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ CommandBuffer & operator=(VkCommandBuffer commandBuffer)\r
+ {\r
+ m_commandBuffer = commandBuffer;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ CommandBuffer & operator=( std::nullptr_t )\r
+ {\r
+ m_commandBuffer = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( CommandBuffer const & rhs ) const\r
+ {\r
+ return m_commandBuffer == rhs.m_commandBuffer;\r
+ }\r
+\r
+ bool operator!=(CommandBuffer const & rhs ) const\r
+ {\r
+ return m_commandBuffer != rhs.m_commandBuffer;\r
+ }\r
+\r
+ bool operator<(CommandBuffer const & rhs ) const\r
+ {\r
+ return m_commandBuffer < rhs.m_commandBuffer;\r
+ }\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result begin( const CommandBufferBeginInfo* pBeginInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type begin( const CommandBufferBeginInfo & beginInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result end(Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type end(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result reset( CommandBufferResetFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type reset( CommandBufferResetFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void bindPipeline( PipelineBindPoint pipelineBindPoint, Pipeline pipeline, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setViewport( uint32_t firstViewport, uint32_t viewportCount, const Viewport* pViewports, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setViewport( uint32_t firstViewport, ArrayProxy<const Viewport> viewports, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setScissor( uint32_t firstScissor, uint32_t scissorCount, const Rect2D* pScissors, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setScissor( uint32_t firstScissor, ArrayProxy<const Rect2D> scissors, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setLineWidth( float lineWidth, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setDepthBias( float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setBlendConstants( const float blendConstants[4], Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setDepthBounds( float minDepthBounds, float maxDepthBounds, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setStencilCompareMask( StencilFaceFlags faceMask, uint32_t compareMask, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setStencilWriteMask( StencilFaceFlags faceMask, uint32_t writeMask, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setStencilReference( StencilFaceFlags faceMask, uint32_t reference, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void bindDescriptorSets( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t firstSet, uint32_t descriptorSetCount, const DescriptorSet* pDescriptorSets, uint32_t dynamicOffsetCount, const uint32_t* pDynamicOffsets, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void bindDescriptorSets( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t firstSet, ArrayProxy<const DescriptorSet> descriptorSets, ArrayProxy<const uint32_t> dynamicOffsets, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void bindIndexBuffer( Buffer buffer, DeviceSize offset, IndexType indexType, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void bindVertexBuffers( uint32_t firstBinding, uint32_t bindingCount, const Buffer* pBuffers, const DeviceSize* pOffsets, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void bindVertexBuffers( uint32_t firstBinding, ArrayProxy<const Buffer> buffers, ArrayProxy<const DeviceSize> offsets, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void draw( uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void drawIndexed( uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void drawIndirect( Buffer buffer, DeviceSize offset, uint32_t drawCount, uint32_t stride, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void drawIndexedIndirect( Buffer buffer, DeviceSize offset, uint32_t drawCount, uint32_t stride, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void dispatch( uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void dispatchIndirect( Buffer buffer, DeviceSize offset, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyBuffer( Buffer srcBuffer, Buffer dstBuffer, uint32_t regionCount, const BufferCopy* pRegions, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyBuffer( Buffer srcBuffer, Buffer dstBuffer, ArrayProxy<const BufferCopy> regions, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const ImageCopy* pRegions, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const ImageCopy> regions, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void blitImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const ImageBlit* pRegions, Filter filter, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void blitImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const ImageBlit> regions, Filter filter, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyBufferToImage( Buffer srcBuffer, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const BufferImageCopy* pRegions, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyBufferToImage( Buffer srcBuffer, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const BufferImageCopy> regions, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyImageToBuffer( Image srcImage, ImageLayout srcImageLayout, Buffer dstBuffer, uint32_t regionCount, const BufferImageCopy* pRegions, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyImageToBuffer( Image srcImage, ImageLayout srcImageLayout, Buffer dstBuffer, ArrayProxy<const BufferImageCopy> regions, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void updateBuffer( Buffer dstBuffer, DeviceSize dstOffset, DeviceSize dataSize, const void* pData, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T, typename Dispatch = DispatchLoaderStatic>\r
+ void updateBuffer( Buffer dstBuffer, DeviceSize dstOffset, ArrayProxy<const T> data, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void fillBuffer( Buffer dstBuffer, DeviceSize dstOffset, DeviceSize size, uint32_t data, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void clearColorImage( Image image, ImageLayout imageLayout, const ClearColorValue* pColor, uint32_t rangeCount, const ImageSubresourceRange* pRanges, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void clearColorImage( Image image, ImageLayout imageLayout, const ClearColorValue & color, ArrayProxy<const ImageSubresourceRange> ranges, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void clearDepthStencilImage( Image image, ImageLayout imageLayout, const ClearDepthStencilValue* pDepthStencil, uint32_t rangeCount, const ImageSubresourceRange* pRanges, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void clearDepthStencilImage( Image image, ImageLayout imageLayout, const ClearDepthStencilValue & depthStencil, ArrayProxy<const ImageSubresourceRange> ranges, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void clearAttachments( uint32_t attachmentCount, const ClearAttachment* pAttachments, uint32_t rectCount, const ClearRect* pRects, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void clearAttachments( ArrayProxy<const ClearAttachment> attachments, ArrayProxy<const ClearRect> rects, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void resolveImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const ImageResolve* pRegions, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void resolveImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const ImageResolve> regions, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setEvent( Event event, PipelineStageFlags stageMask, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void resetEvent( Event event, PipelineStageFlags stageMask, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void waitEvents( uint32_t eventCount, const Event* pEvents, PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, uint32_t memoryBarrierCount, const MemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const BufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const ImageMemoryBarrier* pImageMemoryBarriers, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void waitEvents( ArrayProxy<const Event> events, PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, ArrayProxy<const MemoryBarrier> memoryBarriers, ArrayProxy<const BufferMemoryBarrier> bufferMemoryBarriers, ArrayProxy<const ImageMemoryBarrier> imageMemoryBarriers, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void pipelineBarrier( PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, DependencyFlags dependencyFlags, uint32_t memoryBarrierCount, const MemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const BufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const ImageMemoryBarrier* pImageMemoryBarriers, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void pipelineBarrier( PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, DependencyFlags dependencyFlags, ArrayProxy<const MemoryBarrier> memoryBarriers, ArrayProxy<const BufferMemoryBarrier> bufferMemoryBarriers, ArrayProxy<const ImageMemoryBarrier> imageMemoryBarriers, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginQuery( QueryPool queryPool, uint32_t query, QueryControlFlags flags, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void endQuery( QueryPool queryPool, uint32_t query, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void resetQueryPool( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void writeTimestamp( PipelineStageFlagBits pipelineStage, QueryPool queryPool, uint32_t query, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void copyQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, Buffer dstBuffer, DeviceSize dstOffset, DeviceSize stride, QueryResultFlags flags, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void pushConstants( PipelineLayout layout, ShaderStageFlags stageFlags, uint32_t offset, uint32_t size, const void* pValues, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T, typename Dispatch = DispatchLoaderStatic>\r
+ void pushConstants( PipelineLayout layout, ShaderStageFlags stageFlags, uint32_t offset, ArrayProxy<const T> values, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginRenderPass( const RenderPassBeginInfo* pRenderPassBegin, SubpassContents contents, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginRenderPass( const RenderPassBeginInfo & renderPassBegin, SubpassContents contents, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void nextSubpass( SubpassContents contents, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void endRenderPass(Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void executeCommands( uint32_t commandBufferCount, const CommandBuffer* pCommandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void executeCommands( ArrayProxy<const CommandBuffer> commandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugMarkerBeginEXT( const DebugMarkerMarkerInfoEXT* pMarkerInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugMarkerBeginEXT( const DebugMarkerMarkerInfoEXT & markerInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugMarkerEndEXT(Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugMarkerInsertEXT( const DebugMarkerMarkerInfoEXT* pMarkerInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugMarkerInsertEXT( const DebugMarkerMarkerInfoEXT & markerInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void drawIndirectCountAMD( Buffer buffer, DeviceSize offset, Buffer countBuffer, DeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void drawIndexedIndirectCountAMD( Buffer buffer, DeviceSize offset, Buffer countBuffer, DeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void processCommandsNVX( const CmdProcessCommandsInfoNVX* pProcessCommandsInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void processCommandsNVX( const CmdProcessCommandsInfoNVX & processCommandsInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void reserveSpaceForCommandsNVX( const CmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void reserveSpaceForCommandsNVX( const CmdReserveSpaceForCommandsInfoNVX & reserveSpaceInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void pushDescriptorSetKHR( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t set, uint32_t descriptorWriteCount, const WriteDescriptorSet* pDescriptorWrites, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void pushDescriptorSetKHR( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t set, ArrayProxy<const WriteDescriptorSet> descriptorWrites, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setDeviceMask( uint32_t deviceMask, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setDeviceMaskKHR( uint32_t deviceMask, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void dispatchBase( uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void dispatchBaseKHR( uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void pushDescriptorSetWithTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, PipelineLayout layout, uint32_t set, const void* pData, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setViewportWScalingNV( uint32_t firstViewport, uint32_t viewportCount, const ViewportWScalingNV* pViewportWScalings, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setViewportWScalingNV( uint32_t firstViewport, ArrayProxy<const ViewportWScalingNV> viewportWScalings, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setDiscardRectangleEXT( uint32_t firstDiscardRectangle, uint32_t discardRectangleCount, const Rect2D* pDiscardRectangles, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setDiscardRectangleEXT( uint32_t firstDiscardRectangle, ArrayProxy<const Rect2D> discardRectangles, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setSampleLocationsEXT( const SampleLocationsInfoEXT* pSampleLocationsInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setSampleLocationsEXT( const SampleLocationsInfoEXT & sampleLocationsInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void endDebugUtilsLabelEXT(Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void writeBufferMarkerAMD( PipelineStageFlagBits pipelineStage, Buffer dstBuffer, DeviceSize dstOffset, uint32_t marker, Dispatch const &d = Dispatch() ) const;\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkCommandBuffer() const\r
+ {\r
+ return m_commandBuffer;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_commandBuffer != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_commandBuffer == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkCommandBuffer m_commandBuffer;\r
+ };\r
+\r
+ static_assert( sizeof( CommandBuffer ) == sizeof( VkCommandBuffer ), "handle and wrapper have different size!" );\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result CommandBuffer::begin( const CommandBufferBeginInfo* pBeginInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBeginCommandBuffer( m_commandBuffer, reinterpret_cast<const VkCommandBufferBeginInfo*>( pBeginInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type CommandBuffer::begin( const CommandBufferBeginInfo & beginInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBeginCommandBuffer( m_commandBuffer, reinterpret_cast<const VkCommandBufferBeginInfo*>( &beginInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::CommandBuffer::begin" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result CommandBuffer::end(Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkEndCommandBuffer( m_commandBuffer ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type CommandBuffer::end(Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkEndCommandBuffer( m_commandBuffer ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::CommandBuffer::end" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result CommandBuffer::reset( CommandBufferResetFlags flags, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkResetCommandBuffer( m_commandBuffer, static_cast<VkCommandBufferResetFlags>( flags ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type CommandBuffer::reset( CommandBufferResetFlags flags, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkResetCommandBuffer( m_commandBuffer, static_cast<VkCommandBufferResetFlags>( flags ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::CommandBuffer::reset" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindPipeline( PipelineBindPoint pipelineBindPoint, Pipeline pipeline, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBindPipeline( m_commandBuffer, static_cast<VkPipelineBindPoint>( pipelineBindPoint ), static_cast<VkPipeline>( pipeline ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindPipeline( PipelineBindPoint pipelineBindPoint, Pipeline pipeline, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBindPipeline( m_commandBuffer, static_cast<VkPipelineBindPoint>( pipelineBindPoint ), static_cast<VkPipeline>( pipeline ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setViewport( uint32_t firstViewport, uint32_t viewportCount, const Viewport* pViewports, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetViewport( m_commandBuffer, firstViewport, viewportCount, reinterpret_cast<const VkViewport*>( pViewports ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setViewport( uint32_t firstViewport, ArrayProxy<const Viewport> viewports, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetViewport( m_commandBuffer, firstViewport, viewports.size() , reinterpret_cast<const VkViewport*>( viewports.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setScissor( uint32_t firstScissor, uint32_t scissorCount, const Rect2D* pScissors, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetScissor( m_commandBuffer, firstScissor, scissorCount, reinterpret_cast<const VkRect2D*>( pScissors ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setScissor( uint32_t firstScissor, ArrayProxy<const Rect2D> scissors, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetScissor( m_commandBuffer, firstScissor, scissors.size() , reinterpret_cast<const VkRect2D*>( scissors.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setLineWidth( float lineWidth, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetLineWidth( m_commandBuffer, lineWidth );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setLineWidth( float lineWidth, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetLineWidth( m_commandBuffer, lineWidth );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDepthBias( float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetDepthBias( m_commandBuffer, depthBiasConstantFactor, depthBiasClamp, depthBiasSlopeFactor );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDepthBias( float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetDepthBias( m_commandBuffer, depthBiasConstantFactor, depthBiasClamp, depthBiasSlopeFactor );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setBlendConstants( const float blendConstants[4], Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetBlendConstants( m_commandBuffer, blendConstants );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setBlendConstants( const float blendConstants[4], Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetBlendConstants( m_commandBuffer, blendConstants );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDepthBounds( float minDepthBounds, float maxDepthBounds, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetDepthBounds( m_commandBuffer, minDepthBounds, maxDepthBounds );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDepthBounds( float minDepthBounds, float maxDepthBounds, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetDepthBounds( m_commandBuffer, minDepthBounds, maxDepthBounds );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setStencilCompareMask( StencilFaceFlags faceMask, uint32_t compareMask, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetStencilCompareMask( m_commandBuffer, static_cast<VkStencilFaceFlags>( faceMask ), compareMask );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setStencilCompareMask( StencilFaceFlags faceMask, uint32_t compareMask, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetStencilCompareMask( m_commandBuffer, static_cast<VkStencilFaceFlags>( faceMask ), compareMask );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setStencilWriteMask( StencilFaceFlags faceMask, uint32_t writeMask, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetStencilWriteMask( m_commandBuffer, static_cast<VkStencilFaceFlags>( faceMask ), writeMask );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setStencilWriteMask( StencilFaceFlags faceMask, uint32_t writeMask, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetStencilWriteMask( m_commandBuffer, static_cast<VkStencilFaceFlags>( faceMask ), writeMask );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setStencilReference( StencilFaceFlags faceMask, uint32_t reference, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetStencilReference( m_commandBuffer, static_cast<VkStencilFaceFlags>( faceMask ), reference );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setStencilReference( StencilFaceFlags faceMask, uint32_t reference, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetStencilReference( m_commandBuffer, static_cast<VkStencilFaceFlags>( faceMask ), reference );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindDescriptorSets( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t firstSet, uint32_t descriptorSetCount, const DescriptorSet* pDescriptorSets, uint32_t dynamicOffsetCount, const uint32_t* pDynamicOffsets, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBindDescriptorSets( m_commandBuffer, static_cast<VkPipelineBindPoint>( pipelineBindPoint ), static_cast<VkPipelineLayout>( layout ), firstSet, descriptorSetCount, reinterpret_cast<const VkDescriptorSet*>( pDescriptorSets ), dynamicOffsetCount, pDynamicOffsets );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindDescriptorSets( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t firstSet, ArrayProxy<const DescriptorSet> descriptorSets, ArrayProxy<const uint32_t> dynamicOffsets, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBindDescriptorSets( m_commandBuffer, static_cast<VkPipelineBindPoint>( pipelineBindPoint ), static_cast<VkPipelineLayout>( layout ), firstSet, descriptorSets.size() , reinterpret_cast<const VkDescriptorSet*>( descriptorSets.data() ), dynamicOffsets.size() , dynamicOffsets.data() );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindIndexBuffer( Buffer buffer, DeviceSize offset, IndexType indexType, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBindIndexBuffer( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, static_cast<VkIndexType>( indexType ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindIndexBuffer( Buffer buffer, DeviceSize offset, IndexType indexType, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBindIndexBuffer( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, static_cast<VkIndexType>( indexType ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindVertexBuffers( uint32_t firstBinding, uint32_t bindingCount, const Buffer* pBuffers, const DeviceSize* pOffsets, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBindVertexBuffers( m_commandBuffer, firstBinding, bindingCount, reinterpret_cast<const VkBuffer*>( pBuffers ), pOffsets );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::bindVertexBuffers( uint32_t firstBinding, ArrayProxy<const Buffer> buffers, ArrayProxy<const DeviceSize> offsets, Dispatch const &d ) const\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( buffers.size() == offsets.size() );\r
+#else\r
+ if ( buffers.size() != offsets.size() )\r
+ {\r
+ throw LogicError( VULKAN_HPP_NAMESPACE_STRING "::CommandBuffer::bindVertexBuffers: buffers.size() != offsets.size()" );\r
+ }\r
+#endif // VULKAN_HPP_NO_EXCEPTIONS\r
+ d.vkCmdBindVertexBuffers( m_commandBuffer, firstBinding, buffers.size() , reinterpret_cast<const VkBuffer*>( buffers.data() ), offsets.data() );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::draw( uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDraw( m_commandBuffer, vertexCount, instanceCount, firstVertex, firstInstance );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::draw( uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDraw( m_commandBuffer, vertexCount, instanceCount, firstVertex, firstInstance );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndexed( uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDrawIndexed( m_commandBuffer, indexCount, instanceCount, firstIndex, vertexOffset, firstInstance );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndexed( uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDrawIndexed( m_commandBuffer, indexCount, instanceCount, firstIndex, vertexOffset, firstInstance );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndirect( Buffer buffer, DeviceSize offset, uint32_t drawCount, uint32_t stride, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDrawIndirect( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, drawCount, stride );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndirect( Buffer buffer, DeviceSize offset, uint32_t drawCount, uint32_t stride, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDrawIndirect( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, drawCount, stride );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndexedIndirect( Buffer buffer, DeviceSize offset, uint32_t drawCount, uint32_t stride, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDrawIndexedIndirect( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, drawCount, stride );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndexedIndirect( Buffer buffer, DeviceSize offset, uint32_t drawCount, uint32_t stride, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDrawIndexedIndirect( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, drawCount, stride );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatch( uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDispatch( m_commandBuffer, groupCountX, groupCountY, groupCountZ );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatch( uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDispatch( m_commandBuffer, groupCountX, groupCountY, groupCountZ );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatchIndirect( Buffer buffer, DeviceSize offset, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDispatchIndirect( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatchIndirect( Buffer buffer, DeviceSize offset, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDispatchIndirect( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyBuffer( Buffer srcBuffer, Buffer dstBuffer, uint32_t regionCount, const BufferCopy* pRegions, Dispatch const &d) const\r
+ {\r
+ d.vkCmdCopyBuffer( m_commandBuffer, static_cast<VkBuffer>( srcBuffer ), static_cast<VkBuffer>( dstBuffer ), regionCount, reinterpret_cast<const VkBufferCopy*>( pRegions ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyBuffer( Buffer srcBuffer, Buffer dstBuffer, ArrayProxy<const BufferCopy> regions, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdCopyBuffer( m_commandBuffer, static_cast<VkBuffer>( srcBuffer ), static_cast<VkBuffer>( dstBuffer ), regions.size() , reinterpret_cast<const VkBufferCopy*>( regions.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const ImageCopy* pRegions, Dispatch const &d) const\r
+ {\r
+ d.vkCmdCopyImage( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regionCount, reinterpret_cast<const VkImageCopy*>( pRegions ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const ImageCopy> regions, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdCopyImage( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regions.size() , reinterpret_cast<const VkImageCopy*>( regions.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::blitImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const ImageBlit* pRegions, Filter filter, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBlitImage( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regionCount, reinterpret_cast<const VkImageBlit*>( pRegions ), static_cast<VkFilter>( filter ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::blitImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const ImageBlit> regions, Filter filter, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBlitImage( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regions.size() , reinterpret_cast<const VkImageBlit*>( regions.data() ), static_cast<VkFilter>( filter ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyBufferToImage( Buffer srcBuffer, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const BufferImageCopy* pRegions, Dispatch const &d) const\r
+ {\r
+ d.vkCmdCopyBufferToImage( m_commandBuffer, static_cast<VkBuffer>( srcBuffer ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regionCount, reinterpret_cast<const VkBufferImageCopy*>( pRegions ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyBufferToImage( Buffer srcBuffer, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const BufferImageCopy> regions, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdCopyBufferToImage( m_commandBuffer, static_cast<VkBuffer>( srcBuffer ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regions.size() , reinterpret_cast<const VkBufferImageCopy*>( regions.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyImageToBuffer( Image srcImage, ImageLayout srcImageLayout, Buffer dstBuffer, uint32_t regionCount, const BufferImageCopy* pRegions, Dispatch const &d) const\r
+ {\r
+ d.vkCmdCopyImageToBuffer( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkBuffer>( dstBuffer ), regionCount, reinterpret_cast<const VkBufferImageCopy*>( pRegions ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyImageToBuffer( Image srcImage, ImageLayout srcImageLayout, Buffer dstBuffer, ArrayProxy<const BufferImageCopy> regions, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdCopyImageToBuffer( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkBuffer>( dstBuffer ), regions.size() , reinterpret_cast<const VkBufferImageCopy*>( regions.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::updateBuffer( Buffer dstBuffer, DeviceSize dstOffset, DeviceSize dataSize, const void* pData, Dispatch const &d) const\r
+ {\r
+ d.vkCmdUpdateBuffer( m_commandBuffer, static_cast<VkBuffer>( dstBuffer ), dstOffset, dataSize, pData );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T, typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::updateBuffer( Buffer dstBuffer, DeviceSize dstOffset, ArrayProxy<const T> data, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdUpdateBuffer( m_commandBuffer, static_cast<VkBuffer>( dstBuffer ), dstOffset, data.size() * sizeof( T ) , reinterpret_cast<const void*>( data.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::fillBuffer( Buffer dstBuffer, DeviceSize dstOffset, DeviceSize size, uint32_t data, Dispatch const &d) const\r
+ {\r
+ d.vkCmdFillBuffer( m_commandBuffer, static_cast<VkBuffer>( dstBuffer ), dstOffset, size, data );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::fillBuffer( Buffer dstBuffer, DeviceSize dstOffset, DeviceSize size, uint32_t data, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdFillBuffer( m_commandBuffer, static_cast<VkBuffer>( dstBuffer ), dstOffset, size, data );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::clearColorImage( Image image, ImageLayout imageLayout, const ClearColorValue* pColor, uint32_t rangeCount, const ImageSubresourceRange* pRanges, Dispatch const &d) const\r
+ {\r
+ d.vkCmdClearColorImage( m_commandBuffer, static_cast<VkImage>( image ), static_cast<VkImageLayout>( imageLayout ), reinterpret_cast<const VkClearColorValue*>( pColor ), rangeCount, reinterpret_cast<const VkImageSubresourceRange*>( pRanges ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::clearColorImage( Image image, ImageLayout imageLayout, const ClearColorValue & color, ArrayProxy<const ImageSubresourceRange> ranges, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdClearColorImage( m_commandBuffer, static_cast<VkImage>( image ), static_cast<VkImageLayout>( imageLayout ), reinterpret_cast<const VkClearColorValue*>( &color ), ranges.size() , reinterpret_cast<const VkImageSubresourceRange*>( ranges.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::clearDepthStencilImage( Image image, ImageLayout imageLayout, const ClearDepthStencilValue* pDepthStencil, uint32_t rangeCount, const ImageSubresourceRange* pRanges, Dispatch const &d) const\r
+ {\r
+ d.vkCmdClearDepthStencilImage( m_commandBuffer, static_cast<VkImage>( image ), static_cast<VkImageLayout>( imageLayout ), reinterpret_cast<const VkClearDepthStencilValue*>( pDepthStencil ), rangeCount, reinterpret_cast<const VkImageSubresourceRange*>( pRanges ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::clearDepthStencilImage( Image image, ImageLayout imageLayout, const ClearDepthStencilValue & depthStencil, ArrayProxy<const ImageSubresourceRange> ranges, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdClearDepthStencilImage( m_commandBuffer, static_cast<VkImage>( image ), static_cast<VkImageLayout>( imageLayout ), reinterpret_cast<const VkClearDepthStencilValue*>( &depthStencil ), ranges.size() , reinterpret_cast<const VkImageSubresourceRange*>( ranges.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::clearAttachments( uint32_t attachmentCount, const ClearAttachment* pAttachments, uint32_t rectCount, const ClearRect* pRects, Dispatch const &d) const\r
+ {\r
+ d.vkCmdClearAttachments( m_commandBuffer, attachmentCount, reinterpret_cast<const VkClearAttachment*>( pAttachments ), rectCount, reinterpret_cast<const VkClearRect*>( pRects ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::clearAttachments( ArrayProxy<const ClearAttachment> attachments, ArrayProxy<const ClearRect> rects, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdClearAttachments( m_commandBuffer, attachments.size() , reinterpret_cast<const VkClearAttachment*>( attachments.data() ), rects.size() , reinterpret_cast<const VkClearRect*>( rects.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::resolveImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, uint32_t regionCount, const ImageResolve* pRegions, Dispatch const &d) const\r
+ {\r
+ d.vkCmdResolveImage( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regionCount, reinterpret_cast<const VkImageResolve*>( pRegions ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::resolveImage( Image srcImage, ImageLayout srcImageLayout, Image dstImage, ImageLayout dstImageLayout, ArrayProxy<const ImageResolve> regions, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdResolveImage( m_commandBuffer, static_cast<VkImage>( srcImage ), static_cast<VkImageLayout>( srcImageLayout ), static_cast<VkImage>( dstImage ), static_cast<VkImageLayout>( dstImageLayout ), regions.size() , reinterpret_cast<const VkImageResolve*>( regions.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setEvent( Event event, PipelineStageFlags stageMask, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetEvent( m_commandBuffer, static_cast<VkEvent>( event ), static_cast<VkPipelineStageFlags>( stageMask ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setEvent( Event event, PipelineStageFlags stageMask, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetEvent( m_commandBuffer, static_cast<VkEvent>( event ), static_cast<VkPipelineStageFlags>( stageMask ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::resetEvent( Event event, PipelineStageFlags stageMask, Dispatch const &d) const\r
+ {\r
+ d.vkCmdResetEvent( m_commandBuffer, static_cast<VkEvent>( event ), static_cast<VkPipelineStageFlags>( stageMask ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::resetEvent( Event event, PipelineStageFlags stageMask, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdResetEvent( m_commandBuffer, static_cast<VkEvent>( event ), static_cast<VkPipelineStageFlags>( stageMask ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::waitEvents( uint32_t eventCount, const Event* pEvents, PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, uint32_t memoryBarrierCount, const MemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const BufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const ImageMemoryBarrier* pImageMemoryBarriers, Dispatch const &d) const\r
+ {\r
+ d.vkCmdWaitEvents( m_commandBuffer, eventCount, reinterpret_cast<const VkEvent*>( pEvents ), static_cast<VkPipelineStageFlags>( srcStageMask ), static_cast<VkPipelineStageFlags>( dstStageMask ), memoryBarrierCount, reinterpret_cast<const VkMemoryBarrier*>( pMemoryBarriers ), bufferMemoryBarrierCount, reinterpret_cast<const VkBufferMemoryBarrier*>( pBufferMemoryBarriers ), imageMemoryBarrierCount, reinterpret_cast<const VkImageMemoryBarrier*>( pImageMemoryBarriers ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::waitEvents( ArrayProxy<const Event> events, PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, ArrayProxy<const MemoryBarrier> memoryBarriers, ArrayProxy<const BufferMemoryBarrier> bufferMemoryBarriers, ArrayProxy<const ImageMemoryBarrier> imageMemoryBarriers, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdWaitEvents( m_commandBuffer, events.size() , reinterpret_cast<const VkEvent*>( events.data() ), static_cast<VkPipelineStageFlags>( srcStageMask ), static_cast<VkPipelineStageFlags>( dstStageMask ), memoryBarriers.size() , reinterpret_cast<const VkMemoryBarrier*>( memoryBarriers.data() ), bufferMemoryBarriers.size() , reinterpret_cast<const VkBufferMemoryBarrier*>( bufferMemoryBarriers.data() ), imageMemoryBarriers.size() , reinterpret_cast<const VkImageMemoryBarrier*>( imageMemoryBarriers.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pipelineBarrier( PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, DependencyFlags dependencyFlags, uint32_t memoryBarrierCount, const MemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const BufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const ImageMemoryBarrier* pImageMemoryBarriers, Dispatch const &d) const\r
+ {\r
+ d.vkCmdPipelineBarrier( m_commandBuffer, static_cast<VkPipelineStageFlags>( srcStageMask ), static_cast<VkPipelineStageFlags>( dstStageMask ), static_cast<VkDependencyFlags>( dependencyFlags ), memoryBarrierCount, reinterpret_cast<const VkMemoryBarrier*>( pMemoryBarriers ), bufferMemoryBarrierCount, reinterpret_cast<const VkBufferMemoryBarrier*>( pBufferMemoryBarriers ), imageMemoryBarrierCount, reinterpret_cast<const VkImageMemoryBarrier*>( pImageMemoryBarriers ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pipelineBarrier( PipelineStageFlags srcStageMask, PipelineStageFlags dstStageMask, DependencyFlags dependencyFlags, ArrayProxy<const MemoryBarrier> memoryBarriers, ArrayProxy<const BufferMemoryBarrier> bufferMemoryBarriers, ArrayProxy<const ImageMemoryBarrier> imageMemoryBarriers, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdPipelineBarrier( m_commandBuffer, static_cast<VkPipelineStageFlags>( srcStageMask ), static_cast<VkPipelineStageFlags>( dstStageMask ), static_cast<VkDependencyFlags>( dependencyFlags ), memoryBarriers.size() , reinterpret_cast<const VkMemoryBarrier*>( memoryBarriers.data() ), bufferMemoryBarriers.size() , reinterpret_cast<const VkBufferMemoryBarrier*>( bufferMemoryBarriers.data() ), imageMemoryBarriers.size() , reinterpret_cast<const VkImageMemoryBarrier*>( imageMemoryBarriers.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::beginQuery( QueryPool queryPool, uint32_t query, QueryControlFlags flags, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBeginQuery( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), query, static_cast<VkQueryControlFlags>( flags ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::beginQuery( QueryPool queryPool, uint32_t query, QueryControlFlags flags, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBeginQuery( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), query, static_cast<VkQueryControlFlags>( flags ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::endQuery( QueryPool queryPool, uint32_t query, Dispatch const &d) const\r
+ {\r
+ d.vkCmdEndQuery( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), query );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::endQuery( QueryPool queryPool, uint32_t query, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdEndQuery( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), query );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::resetQueryPool( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, Dispatch const &d) const\r
+ {\r
+ d.vkCmdResetQueryPool( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), firstQuery, queryCount );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::resetQueryPool( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdResetQueryPool( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), firstQuery, queryCount );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::writeTimestamp( PipelineStageFlagBits pipelineStage, QueryPool queryPool, uint32_t query, Dispatch const &d) const\r
+ {\r
+ d.vkCmdWriteTimestamp( m_commandBuffer, static_cast<VkPipelineStageFlagBits>( pipelineStage ), static_cast<VkQueryPool>( queryPool ), query );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::writeTimestamp( PipelineStageFlagBits pipelineStage, QueryPool queryPool, uint32_t query, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdWriteTimestamp( m_commandBuffer, static_cast<VkPipelineStageFlagBits>( pipelineStage ), static_cast<VkQueryPool>( queryPool ), query );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, Buffer dstBuffer, DeviceSize dstOffset, DeviceSize stride, QueryResultFlags flags, Dispatch const &d) const\r
+ {\r
+ d.vkCmdCopyQueryPoolResults( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), firstQuery, queryCount, static_cast<VkBuffer>( dstBuffer ), dstOffset, stride, static_cast<VkQueryResultFlags>( flags ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::copyQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, Buffer dstBuffer, DeviceSize dstOffset, DeviceSize stride, QueryResultFlags flags, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdCopyQueryPoolResults( m_commandBuffer, static_cast<VkQueryPool>( queryPool ), firstQuery, queryCount, static_cast<VkBuffer>( dstBuffer ), dstOffset, stride, static_cast<VkQueryResultFlags>( flags ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pushConstants( PipelineLayout layout, ShaderStageFlags stageFlags, uint32_t offset, uint32_t size, const void* pValues, Dispatch const &d) const\r
+ {\r
+ d.vkCmdPushConstants( m_commandBuffer, static_cast<VkPipelineLayout>( layout ), static_cast<VkShaderStageFlags>( stageFlags ), offset, size, pValues );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T, typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pushConstants( PipelineLayout layout, ShaderStageFlags stageFlags, uint32_t offset, ArrayProxy<const T> values, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdPushConstants( m_commandBuffer, static_cast<VkPipelineLayout>( layout ), static_cast<VkShaderStageFlags>( stageFlags ), offset, values.size() * sizeof( T ) , reinterpret_cast<const void*>( values.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::beginRenderPass( const RenderPassBeginInfo* pRenderPassBegin, SubpassContents contents, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBeginRenderPass( m_commandBuffer, reinterpret_cast<const VkRenderPassBeginInfo*>( pRenderPassBegin ), static_cast<VkSubpassContents>( contents ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::beginRenderPass( const RenderPassBeginInfo & renderPassBegin, SubpassContents contents, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBeginRenderPass( m_commandBuffer, reinterpret_cast<const VkRenderPassBeginInfo*>( &renderPassBegin ), static_cast<VkSubpassContents>( contents ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::nextSubpass( SubpassContents contents, Dispatch const &d) const\r
+ {\r
+ d.vkCmdNextSubpass( m_commandBuffer, static_cast<VkSubpassContents>( contents ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::nextSubpass( SubpassContents contents, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdNextSubpass( m_commandBuffer, static_cast<VkSubpassContents>( contents ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::endRenderPass(Dispatch const &d) const\r
+ {\r
+ d.vkCmdEndRenderPass( m_commandBuffer );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::endRenderPass(Dispatch const &d ) const\r
+ {\r
+ d.vkCmdEndRenderPass( m_commandBuffer );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::executeCommands( uint32_t commandBufferCount, const CommandBuffer* pCommandBuffers, Dispatch const &d) const\r
+ {\r
+ d.vkCmdExecuteCommands( m_commandBuffer, commandBufferCount, reinterpret_cast<const VkCommandBuffer*>( pCommandBuffers ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::executeCommands( ArrayProxy<const CommandBuffer> commandBuffers, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdExecuteCommands( m_commandBuffer, commandBuffers.size() , reinterpret_cast<const VkCommandBuffer*>( commandBuffers.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::debugMarkerBeginEXT( const DebugMarkerMarkerInfoEXT* pMarkerInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDebugMarkerBeginEXT( m_commandBuffer, reinterpret_cast<const VkDebugMarkerMarkerInfoEXT*>( pMarkerInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::debugMarkerBeginEXT( const DebugMarkerMarkerInfoEXT & markerInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDebugMarkerBeginEXT( m_commandBuffer, reinterpret_cast<const VkDebugMarkerMarkerInfoEXT*>( &markerInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::debugMarkerEndEXT(Dispatch const &d) const\r
+ {\r
+ d.vkCmdDebugMarkerEndEXT( m_commandBuffer );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::debugMarkerEndEXT(Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDebugMarkerEndEXT( m_commandBuffer );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::debugMarkerInsertEXT( const DebugMarkerMarkerInfoEXT* pMarkerInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDebugMarkerInsertEXT( m_commandBuffer, reinterpret_cast<const VkDebugMarkerMarkerInfoEXT*>( pMarkerInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::debugMarkerInsertEXT( const DebugMarkerMarkerInfoEXT & markerInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDebugMarkerInsertEXT( m_commandBuffer, reinterpret_cast<const VkDebugMarkerMarkerInfoEXT*>( &markerInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndirectCountAMD( Buffer buffer, DeviceSize offset, Buffer countBuffer, DeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDrawIndirectCountAMD( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, static_cast<VkBuffer>( countBuffer ), countBufferOffset, maxDrawCount, stride );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndirectCountAMD( Buffer buffer, DeviceSize offset, Buffer countBuffer, DeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDrawIndirectCountAMD( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, static_cast<VkBuffer>( countBuffer ), countBufferOffset, maxDrawCount, stride );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndexedIndirectCountAMD( Buffer buffer, DeviceSize offset, Buffer countBuffer, DeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDrawIndexedIndirectCountAMD( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, static_cast<VkBuffer>( countBuffer ), countBufferOffset, maxDrawCount, stride );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::drawIndexedIndirectCountAMD( Buffer buffer, DeviceSize offset, Buffer countBuffer, DeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDrawIndexedIndirectCountAMD( m_commandBuffer, static_cast<VkBuffer>( buffer ), offset, static_cast<VkBuffer>( countBuffer ), countBufferOffset, maxDrawCount, stride );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::processCommandsNVX( const CmdProcessCommandsInfoNVX* pProcessCommandsInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdProcessCommandsNVX( m_commandBuffer, reinterpret_cast<const VkCmdProcessCommandsInfoNVX*>( pProcessCommandsInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::processCommandsNVX( const CmdProcessCommandsInfoNVX & processCommandsInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdProcessCommandsNVX( m_commandBuffer, reinterpret_cast<const VkCmdProcessCommandsInfoNVX*>( &processCommandsInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::reserveSpaceForCommandsNVX( const CmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdReserveSpaceForCommandsNVX( m_commandBuffer, reinterpret_cast<const VkCmdReserveSpaceForCommandsInfoNVX*>( pReserveSpaceInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::reserveSpaceForCommandsNVX( const CmdReserveSpaceForCommandsInfoNVX & reserveSpaceInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdReserveSpaceForCommandsNVX( m_commandBuffer, reinterpret_cast<const VkCmdReserveSpaceForCommandsInfoNVX*>( &reserveSpaceInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pushDescriptorSetKHR( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t set, uint32_t descriptorWriteCount, const WriteDescriptorSet* pDescriptorWrites, Dispatch const &d) const\r
+ {\r
+ d.vkCmdPushDescriptorSetKHR( m_commandBuffer, static_cast<VkPipelineBindPoint>( pipelineBindPoint ), static_cast<VkPipelineLayout>( layout ), set, descriptorWriteCount, reinterpret_cast<const VkWriteDescriptorSet*>( pDescriptorWrites ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pushDescriptorSetKHR( PipelineBindPoint pipelineBindPoint, PipelineLayout layout, uint32_t set, ArrayProxy<const WriteDescriptorSet> descriptorWrites, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdPushDescriptorSetKHR( m_commandBuffer, static_cast<VkPipelineBindPoint>( pipelineBindPoint ), static_cast<VkPipelineLayout>( layout ), set, descriptorWrites.size() , reinterpret_cast<const VkWriteDescriptorSet*>( descriptorWrites.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDeviceMask( uint32_t deviceMask, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetDeviceMask( m_commandBuffer, deviceMask );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDeviceMask( uint32_t deviceMask, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetDeviceMask( m_commandBuffer, deviceMask );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDeviceMaskKHR( uint32_t deviceMask, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetDeviceMaskKHR( m_commandBuffer, deviceMask );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDeviceMaskKHR( uint32_t deviceMask, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetDeviceMaskKHR( m_commandBuffer, deviceMask );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatchBase( uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDispatchBase( m_commandBuffer, baseGroupX, baseGroupY, baseGroupZ, groupCountX, groupCountY, groupCountZ );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatchBase( uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDispatchBase( m_commandBuffer, baseGroupX, baseGroupY, baseGroupZ, groupCountX, groupCountY, groupCountZ );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatchBaseKHR( uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d) const\r
+ {\r
+ d.vkCmdDispatchBaseKHR( m_commandBuffer, baseGroupX, baseGroupY, baseGroupZ, groupCountX, groupCountY, groupCountZ );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::dispatchBaseKHR( uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdDispatchBaseKHR( m_commandBuffer, baseGroupX, baseGroupY, baseGroupZ, groupCountX, groupCountY, groupCountZ );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pushDescriptorSetWithTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, PipelineLayout layout, uint32_t set, const void* pData, Dispatch const &d) const\r
+ {\r
+ d.vkCmdPushDescriptorSetWithTemplateKHR( m_commandBuffer, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), static_cast<VkPipelineLayout>( layout ), set, pData );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::pushDescriptorSetWithTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, PipelineLayout layout, uint32_t set, const void* pData, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdPushDescriptorSetWithTemplateKHR( m_commandBuffer, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), static_cast<VkPipelineLayout>( layout ), set, pData );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setViewportWScalingNV( uint32_t firstViewport, uint32_t viewportCount, const ViewportWScalingNV* pViewportWScalings, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetViewportWScalingNV( m_commandBuffer, firstViewport, viewportCount, reinterpret_cast<const VkViewportWScalingNV*>( pViewportWScalings ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setViewportWScalingNV( uint32_t firstViewport, ArrayProxy<const ViewportWScalingNV> viewportWScalings, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetViewportWScalingNV( m_commandBuffer, firstViewport, viewportWScalings.size() , reinterpret_cast<const VkViewportWScalingNV*>( viewportWScalings.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDiscardRectangleEXT( uint32_t firstDiscardRectangle, uint32_t discardRectangleCount, const Rect2D* pDiscardRectangles, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetDiscardRectangleEXT( m_commandBuffer, firstDiscardRectangle, discardRectangleCount, reinterpret_cast<const VkRect2D*>( pDiscardRectangles ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setDiscardRectangleEXT( uint32_t firstDiscardRectangle, ArrayProxy<const Rect2D> discardRectangles, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetDiscardRectangleEXT( m_commandBuffer, firstDiscardRectangle, discardRectangles.size() , reinterpret_cast<const VkRect2D*>( discardRectangles.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setSampleLocationsEXT( const SampleLocationsInfoEXT* pSampleLocationsInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdSetSampleLocationsEXT( m_commandBuffer, reinterpret_cast<const VkSampleLocationsInfoEXT*>( pSampleLocationsInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::setSampleLocationsEXT( const SampleLocationsInfoEXT & sampleLocationsInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdSetSampleLocationsEXT( m_commandBuffer, reinterpret_cast<const VkSampleLocationsInfoEXT*>( &sampleLocationsInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdBeginDebugUtilsLabelEXT( m_commandBuffer, reinterpret_cast<const VkDebugUtilsLabelEXT*>( pLabelInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdBeginDebugUtilsLabelEXT( m_commandBuffer, reinterpret_cast<const VkDebugUtilsLabelEXT*>( &labelInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::endDebugUtilsLabelEXT(Dispatch const &d) const\r
+ {\r
+ d.vkCmdEndDebugUtilsLabelEXT( m_commandBuffer );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::endDebugUtilsLabelEXT(Dispatch const &d ) const\r
+ {\r
+ d.vkCmdEndDebugUtilsLabelEXT( m_commandBuffer );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d) const\r
+ {\r
+ d.vkCmdInsertDebugUtilsLabelEXT( m_commandBuffer, reinterpret_cast<const VkDebugUtilsLabelEXT*>( pLabelInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdInsertDebugUtilsLabelEXT( m_commandBuffer, reinterpret_cast<const VkDebugUtilsLabelEXT*>( &labelInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::writeBufferMarkerAMD( PipelineStageFlagBits pipelineStage, Buffer dstBuffer, DeviceSize dstOffset, uint32_t marker, Dispatch const &d) const\r
+ {\r
+ d.vkCmdWriteBufferMarkerAMD( m_commandBuffer, static_cast<VkPipelineStageFlagBits>( pipelineStage ), static_cast<VkBuffer>( dstBuffer ), dstOffset, marker );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void CommandBuffer::writeBufferMarkerAMD( PipelineStageFlagBits pipelineStage, Buffer dstBuffer, DeviceSize dstOffset, uint32_t marker, Dispatch const &d ) const\r
+ {\r
+ d.vkCmdWriteBufferMarkerAMD( m_commandBuffer, static_cast<VkPipelineStageFlagBits>( pipelineStage ), static_cast<VkBuffer>( dstBuffer ), dstOffset, marker );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ struct SubmitInfo\r
+ {\r
+ SubmitInfo( uint32_t waitSemaphoreCount_ = 0, const Semaphore* pWaitSemaphores_ = nullptr, const PipelineStageFlags* pWaitDstStageMask_ = nullptr, uint32_t commandBufferCount_ = 0, const CommandBuffer* pCommandBuffers_ = nullptr, uint32_t signalSemaphoreCount_ = 0, const Semaphore* pSignalSemaphores_ = nullptr )\r
+ : waitSemaphoreCount( waitSemaphoreCount_ )\r
+ , pWaitSemaphores( pWaitSemaphores_ )\r
+ , pWaitDstStageMask( pWaitDstStageMask_ )\r
+ , commandBufferCount( commandBufferCount_ )\r
+ , pCommandBuffers( pCommandBuffers_ )\r
+ , signalSemaphoreCount( signalSemaphoreCount_ )\r
+ , pSignalSemaphores( pSignalSemaphores_ )\r
+ {\r
+ }\r
+\r
+ SubmitInfo( VkSubmitInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubmitInfo ) );\r
+ }\r
+\r
+ SubmitInfo& operator=( VkSubmitInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( SubmitInfo ) );\r
+ return *this;\r
+ }\r
+ SubmitInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setWaitSemaphoreCount( uint32_t waitSemaphoreCount_ )\r
+ {\r
+ waitSemaphoreCount = waitSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setPWaitSemaphores( const Semaphore* pWaitSemaphores_ )\r
+ {\r
+ pWaitSemaphores = pWaitSemaphores_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setPWaitDstStageMask( const PipelineStageFlags* pWaitDstStageMask_ )\r
+ {\r
+ pWaitDstStageMask = pWaitDstStageMask_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setCommandBufferCount( uint32_t commandBufferCount_ )\r
+ {\r
+ commandBufferCount = commandBufferCount_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setPCommandBuffers( const CommandBuffer* pCommandBuffers_ )\r
+ {\r
+ pCommandBuffers = pCommandBuffers_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setSignalSemaphoreCount( uint32_t signalSemaphoreCount_ )\r
+ {\r
+ signalSemaphoreCount = signalSemaphoreCount_;\r
+ return *this;\r
+ }\r
+\r
+ SubmitInfo& setPSignalSemaphores( const Semaphore* pSignalSemaphores_ )\r
+ {\r
+ pSignalSemaphores = pSignalSemaphores_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkSubmitInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkSubmitInfo*>(this);\r
+ }\r
+\r
+ bool operator==( SubmitInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( waitSemaphoreCount == rhs.waitSemaphoreCount )\r
+ && ( pWaitSemaphores == rhs.pWaitSemaphores )\r
+ && ( pWaitDstStageMask == rhs.pWaitDstStageMask )\r
+ && ( commandBufferCount == rhs.commandBufferCount )\r
+ && ( pCommandBuffers == rhs.pCommandBuffers )\r
+ && ( signalSemaphoreCount == rhs.signalSemaphoreCount )\r
+ && ( pSignalSemaphores == rhs.pSignalSemaphores );\r
+ }\r
+\r
+ bool operator!=( SubmitInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eSubmitInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t waitSemaphoreCount;\r
+ const Semaphore* pWaitSemaphores;\r
+ const PipelineStageFlags* pWaitDstStageMask;\r
+ uint32_t commandBufferCount;\r
+ const CommandBuffer* pCommandBuffers;\r
+ uint32_t signalSemaphoreCount;\r
+ const Semaphore* pSignalSemaphores;\r
+ };\r
+ static_assert( sizeof( SubmitInfo ) == sizeof( VkSubmitInfo ), "struct and wrapper have different size!" );\r
+\r
+ class Queue\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Queue()\r
+ : m_queue(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Queue( std::nullptr_t )\r
+ : m_queue(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Queue( VkQueue queue )\r
+ : m_queue( queue )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Queue & operator=(VkQueue queue)\r
+ {\r
+ m_queue = queue;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Queue & operator=( std::nullptr_t )\r
+ {\r
+ m_queue = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Queue const & rhs ) const\r
+ {\r
+ return m_queue == rhs.m_queue;\r
+ }\r
+\r
+ bool operator!=(Queue const & rhs ) const\r
+ {\r
+ return m_queue != rhs.m_queue;\r
+ }\r
+\r
+ bool operator<(Queue const & rhs ) const\r
+ {\r
+ return m_queue < rhs.m_queue;\r
+ }\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result submit( uint32_t submitCount, const SubmitInfo* pSubmits, Fence fence, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type submit( ArrayProxy<const SubmitInfo> submits, Fence fence, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result waitIdle(Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type waitIdle(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindSparse( uint32_t bindInfoCount, const BindSparseInfo* pBindInfo, Fence fence, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindSparse( ArrayProxy<const BindSparseInfo> bindInfo, Fence fence, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result presentKHR( const PresentInfoKHR* pPresentInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result presentKHR( const PresentInfoKHR & presentInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void endDebugUtilsLabelEXT(Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkQueue() const\r
+ {\r
+ return m_queue;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_queue != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_queue == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkQueue m_queue;\r
+ };\r
+\r
+ static_assert( sizeof( Queue ) == sizeof( VkQueue ), "handle and wrapper have different size!" );\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Queue::submit( uint32_t submitCount, const SubmitInfo* pSubmits, Fence fence, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkQueueSubmit( m_queue, submitCount, reinterpret_cast<const VkSubmitInfo*>( pSubmits ), static_cast<VkFence>( fence ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Queue::submit( ArrayProxy<const SubmitInfo> submits, Fence fence, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkQueueSubmit( m_queue, submits.size() , reinterpret_cast<const VkSubmitInfo*>( submits.data() ), static_cast<VkFence>( fence ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Queue::submit" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Queue::waitIdle(Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkQueueWaitIdle( m_queue ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Queue::waitIdle(Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkQueueWaitIdle( m_queue ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Queue::waitIdle" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Queue::bindSparse( uint32_t bindInfoCount, const BindSparseInfo* pBindInfo, Fence fence, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkQueueBindSparse( m_queue, bindInfoCount, reinterpret_cast<const VkBindSparseInfo*>( pBindInfo ), static_cast<VkFence>( fence ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Queue::bindSparse( ArrayProxy<const BindSparseInfo> bindInfo, Fence fence, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkQueueBindSparse( m_queue, bindInfo.size() , reinterpret_cast<const VkBindSparseInfo*>( bindInfo.data() ), static_cast<VkFence>( fence ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Queue::bindSparse" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Queue::presentKHR( const PresentInfoKHR* pPresentInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkQueuePresentKHR( m_queue, reinterpret_cast<const VkPresentInfoKHR*>( pPresentInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Queue::presentKHR( const PresentInfoKHR & presentInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkQueuePresentKHR( m_queue, reinterpret_cast<const VkPresentInfoKHR*>( &presentInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Queue::presentKHR", { Result::eSuccess, Result::eSuboptimalKHR } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Queue::beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d) const\r
+ {\r
+ d.vkQueueBeginDebugUtilsLabelEXT( m_queue, reinterpret_cast<const VkDebugUtilsLabelEXT*>( pLabelInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Queue::beginDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkQueueBeginDebugUtilsLabelEXT( m_queue, reinterpret_cast<const VkDebugUtilsLabelEXT*>( &labelInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Queue::endDebugUtilsLabelEXT(Dispatch const &d) const\r
+ {\r
+ d.vkQueueEndDebugUtilsLabelEXT( m_queue );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Queue::endDebugUtilsLabelEXT(Dispatch const &d ) const\r
+ {\r
+ d.vkQueueEndDebugUtilsLabelEXT( m_queue );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Queue::insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT* pLabelInfo, Dispatch const &d) const\r
+ {\r
+ d.vkQueueInsertDebugUtilsLabelEXT( m_queue, reinterpret_cast<const VkDebugUtilsLabelEXT*>( pLabelInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Queue::insertDebugUtilsLabelEXT( const DebugUtilsLabelEXT & labelInfo, Dispatch const &d ) const\r
+ {\r
+ d.vkQueueInsertDebugUtilsLabelEXT( m_queue, reinterpret_cast<const VkDebugUtilsLabelEXT*>( &labelInfo ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ class Device;\r
+\r
+ template <> class UniqueHandleTraits<Buffer> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueBuffer = UniqueHandle<Buffer>;\r
+ template <> class UniqueHandleTraits<BufferView> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueBufferView = UniqueHandle<BufferView>;\r
+ template <> class UniqueHandleTraits<CommandBuffer> {public: using deleter = PoolFree<Device, CommandPool>; };\r
+ using UniqueCommandBuffer = UniqueHandle<CommandBuffer>;\r
+ template <> class UniqueHandleTraits<CommandPool> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueCommandPool = UniqueHandle<CommandPool>;\r
+ template <> class UniqueHandleTraits<DescriptorPool> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueDescriptorPool = UniqueHandle<DescriptorPool>;\r
+ template <> class UniqueHandleTraits<DescriptorSet> {public: using deleter = PoolFree<Device, DescriptorPool>; };\r
+ using UniqueDescriptorSet = UniqueHandle<DescriptorSet>;\r
+ template <> class UniqueHandleTraits<DescriptorSetLayout> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueDescriptorSetLayout = UniqueHandle<DescriptorSetLayout>;\r
+ template <> class UniqueHandleTraits<DescriptorUpdateTemplate> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueDescriptorUpdateTemplate = UniqueHandle<DescriptorUpdateTemplate>;\r
+ template <> class UniqueHandleTraits<DeviceMemory> {public: using deleter = ObjectFree<Device>; };\r
+ using UniqueDeviceMemory = UniqueHandle<DeviceMemory>;\r
+ template <> class UniqueHandleTraits<Event> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueEvent = UniqueHandle<Event>;\r
+ template <> class UniqueHandleTraits<Fence> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueFence = UniqueHandle<Fence>;\r
+ template <> class UniqueHandleTraits<Framebuffer> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueFramebuffer = UniqueHandle<Framebuffer>;\r
+ template <> class UniqueHandleTraits<Image> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueImage = UniqueHandle<Image>;\r
+ template <> class UniqueHandleTraits<ImageView> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueImageView = UniqueHandle<ImageView>;\r
+ template <> class UniqueHandleTraits<IndirectCommandsLayoutNVX> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueIndirectCommandsLayoutNVX = UniqueHandle<IndirectCommandsLayoutNVX>;\r
+ template <> class UniqueHandleTraits<ObjectTableNVX> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueObjectTableNVX = UniqueHandle<ObjectTableNVX>;\r
+ template <> class UniqueHandleTraits<Pipeline> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniquePipeline = UniqueHandle<Pipeline>;\r
+ template <> class UniqueHandleTraits<PipelineCache> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniquePipelineCache = UniqueHandle<PipelineCache>;\r
+ template <> class UniqueHandleTraits<PipelineLayout> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniquePipelineLayout = UniqueHandle<PipelineLayout>;\r
+ template <> class UniqueHandleTraits<QueryPool> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueQueryPool = UniqueHandle<QueryPool>;\r
+ template <> class UniqueHandleTraits<RenderPass> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueRenderPass = UniqueHandle<RenderPass>;\r
+ template <> class UniqueHandleTraits<Sampler> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueSampler = UniqueHandle<Sampler>;\r
+ template <> class UniqueHandleTraits<SamplerYcbcrConversion> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueSamplerYcbcrConversion = UniqueHandle<SamplerYcbcrConversion>;\r
+ template <> class UniqueHandleTraits<Semaphore> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueSemaphore = UniqueHandle<Semaphore>;\r
+ template <> class UniqueHandleTraits<ShaderModule> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueShaderModule = UniqueHandle<ShaderModule>;\r
+ template <> class UniqueHandleTraits<SwapchainKHR> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueSwapchainKHR = UniqueHandle<SwapchainKHR>;\r
+ template <> class UniqueHandleTraits<ValidationCacheEXT> {public: using deleter = ObjectDestroy<Device>; };\r
+ using UniqueValidationCacheEXT = UniqueHandle<ValidationCacheEXT>;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+\r
+ class Device\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Device()\r
+ : m_device(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Device( std::nullptr_t )\r
+ : m_device(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Device( VkDevice device )\r
+ : m_device( device )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Device & operator=(VkDevice device)\r
+ {\r
+ m_device = device;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Device & operator=( std::nullptr_t )\r
+ {\r
+ m_device = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Device const & rhs ) const\r
+ {\r
+ return m_device == rhs.m_device;\r
+ }\r
+\r
+ bool operator!=(Device const & rhs ) const\r
+ {\r
+ return m_device != rhs.m_device;\r
+ }\r
+\r
+ bool operator<(Device const & rhs ) const\r
+ {\r
+ return m_device < rhs.m_device;\r
+ }\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PFN_vkVoidFunction getProcAddr( const char* pName, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PFN_vkVoidFunction getProcAddr( const std::string & name, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getQueue( uint32_t queueFamilyIndex, uint32_t queueIndex, Queue* pQueue, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Queue getQueue( uint32_t queueFamilyIndex, uint32_t queueIndex, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result waitIdle(Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type waitIdle(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result allocateMemory( const MemoryAllocateInfo* pAllocateInfo, const AllocationCallbacks* pAllocator, DeviceMemory* pMemory, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DeviceMemory>::type allocateMemory( const MemoryAllocateInfo & allocateInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDeviceMemory>::type allocateMemoryUnique( const MemoryAllocateInfo & allocateInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void freeMemory( DeviceMemory memory, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void freeMemory( DeviceMemory memory, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void free( DeviceMemory memory, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void free( DeviceMemory memory, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result mapMemory( DeviceMemory memory, DeviceSize offset, DeviceSize size, MemoryMapFlags flags, void** ppData, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void*>::type mapMemory( DeviceMemory memory, DeviceSize offset, DeviceSize size, MemoryMapFlags flags = MemoryMapFlags(), Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void unmapMemory( DeviceMemory memory, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result flushMappedMemoryRanges( uint32_t memoryRangeCount, const MappedMemoryRange* pMemoryRanges, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type flushMappedMemoryRanges( ArrayProxy<const MappedMemoryRange> memoryRanges, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result invalidateMappedMemoryRanges( uint32_t memoryRangeCount, const MappedMemoryRange* pMemoryRanges, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type invalidateMappedMemoryRanges( ArrayProxy<const MappedMemoryRange> memoryRanges, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getMemoryCommitment( DeviceMemory memory, DeviceSize* pCommittedMemoryInBytes, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ DeviceSize getMemoryCommitment( DeviceMemory memory, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getBufferMemoryRequirements( Buffer buffer, MemoryRequirements* pMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MemoryRequirements getBufferMemoryRequirements( Buffer buffer, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindBufferMemory( Buffer buffer, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindBufferMemory( Buffer buffer, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageMemoryRequirements( Image image, MemoryRequirements* pMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MemoryRequirements getImageMemoryRequirements( Image image, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindImageMemory( Image image, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindImageMemory( Image image, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageSparseMemoryRequirements( Image image, uint32_t* pSparseMemoryRequirementCount, SparseImageMemoryRequirements* pSparseMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SparseImageMemoryRequirements>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<SparseImageMemoryRequirements,Allocator> getImageSparseMemoryRequirements( Image image, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createFence( const FenceCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Fence* pFence, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Fence>::type createFence( const FenceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueFence>::type createFenceUnique( const FenceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyFence( Fence fence, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyFence( Fence fence, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Fence fence, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Fence fence, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result resetFences( uint32_t fenceCount, const Fence* pFences, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type resetFences( ArrayProxy<const Fence> fences, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getFenceStatus( Fence fence, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result waitForFences( uint32_t fenceCount, const Fence* pFences, Bool32 waitAll, uint64_t timeout, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result waitForFences( ArrayProxy<const Fence> fences, Bool32 waitAll, uint64_t timeout, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createSemaphore( const SemaphoreCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Semaphore* pSemaphore, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Semaphore>::type createSemaphore( const SemaphoreCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSemaphore>::type createSemaphoreUnique( const SemaphoreCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySemaphore( Semaphore semaphore, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySemaphore( Semaphore semaphore, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Semaphore semaphore, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Semaphore semaphore, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createEvent( const EventCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Event* pEvent, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Event>::type createEvent( const EventCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueEvent>::type createEventUnique( const EventCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyEvent( Event event, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyEvent( Event event, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Event event, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Event event, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getEventStatus( Event event, Dispatch const &d = Dispatch() ) const;\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result setEvent( Event event, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type setEvent( Event event, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result resetEvent( Event event, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type resetEvent( Event event, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createQueryPool( const QueryPoolCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, QueryPool* pQueryPool, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<QueryPool>::type createQueryPool( const QueryPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueQueryPool>::type createQueryPoolUnique( const QueryPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyQueryPool( QueryPool queryPool, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyQueryPool( QueryPool queryPool, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( QueryPool queryPool, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( QueryPool queryPool, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, size_t dataSize, void* pData, DeviceSize stride, QueryResultFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T, typename Dispatch = DispatchLoaderStatic>\r
+ Result getQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, ArrayProxy<T> data, DeviceSize stride, QueryResultFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createBuffer( const BufferCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Buffer* pBuffer, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Buffer>::type createBuffer( const BufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueBuffer>::type createBufferUnique( const BufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyBuffer( Buffer buffer, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyBuffer( Buffer buffer, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Buffer buffer, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Buffer buffer, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createBufferView( const BufferViewCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, BufferView* pView, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<BufferView>::type createBufferView( const BufferViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueBufferView>::type createBufferViewUnique( const BufferViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyBufferView( BufferView bufferView, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyBufferView( BufferView bufferView, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( BufferView bufferView, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( BufferView bufferView, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createImage( const ImageCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Image* pImage, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Image>::type createImage( const ImageCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueImage>::type createImageUnique( const ImageCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyImage( Image image, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyImage( Image image, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Image image, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Image image, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageSubresourceLayout( Image image, const ImageSubresource* pSubresource, SubresourceLayout* pLayout, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ SubresourceLayout getImageSubresourceLayout( Image image, const ImageSubresource & subresource, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createImageView( const ImageViewCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, ImageView* pView, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ImageView>::type createImageView( const ImageViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueImageView>::type createImageViewUnique( const ImageViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyImageView( ImageView imageView, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyImageView( ImageView imageView, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ImageView imageView, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ImageView imageView, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createShaderModule( const ShaderModuleCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, ShaderModule* pShaderModule, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ShaderModule>::type createShaderModule( const ShaderModuleCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueShaderModule>::type createShaderModuleUnique( const ShaderModuleCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyShaderModule( ShaderModule shaderModule, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyShaderModule( ShaderModule shaderModule, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ShaderModule shaderModule, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ShaderModule shaderModule, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createPipelineCache( const PipelineCacheCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, PipelineCache* pPipelineCache, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<PipelineCache>::type createPipelineCache( const PipelineCacheCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniquePipelineCache>::type createPipelineCacheUnique( const PipelineCacheCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyPipelineCache( PipelineCache pipelineCache, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyPipelineCache( PipelineCache pipelineCache, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( PipelineCache pipelineCache, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( PipelineCache pipelineCache, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getPipelineCacheData( PipelineCache pipelineCache, size_t* pDataSize, void* pData, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<uint8_t>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<uint8_t,Allocator>>::type getPipelineCacheData( PipelineCache pipelineCache, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result mergePipelineCaches( PipelineCache dstCache, uint32_t srcCacheCount, const PipelineCache* pSrcCaches, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type mergePipelineCaches( PipelineCache dstCache, ArrayProxy<const PipelineCache> srcCaches, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createGraphicsPipelines( PipelineCache pipelineCache, uint32_t createInfoCount, const GraphicsPipelineCreateInfo* pCreateInfos, const AllocationCallbacks* pAllocator, Pipeline* pPipelines, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<Pipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<Pipeline,Allocator>>::type createGraphicsPipelines( PipelineCache pipelineCache, ArrayProxy<const GraphicsPipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+ template <typename Allocator = std::allocator<Pipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ ResultValueType<Pipeline>::type createGraphicsPipeline( PipelineCache pipelineCache, const GraphicsPipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator = std::allocator<UniquePipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<UniquePipeline,Allocator>>::type createGraphicsPipelinesUnique( PipelineCache pipelineCache, ArrayProxy<const GraphicsPipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+ template <typename Allocator = std::allocator<UniquePipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ ResultValueType<UniquePipeline>::type createGraphicsPipelineUnique( PipelineCache pipelineCache, const GraphicsPipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createComputePipelines( PipelineCache pipelineCache, uint32_t createInfoCount, const ComputePipelineCreateInfo* pCreateInfos, const AllocationCallbacks* pAllocator, Pipeline* pPipelines, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<Pipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<Pipeline,Allocator>>::type createComputePipelines( PipelineCache pipelineCache, ArrayProxy<const ComputePipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+ template <typename Allocator = std::allocator<Pipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ ResultValueType<Pipeline>::type createComputePipeline( PipelineCache pipelineCache, const ComputePipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator = std::allocator<UniquePipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<UniquePipeline,Allocator>>::type createComputePipelinesUnique( PipelineCache pipelineCache, ArrayProxy<const ComputePipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+ template <typename Allocator = std::allocator<UniquePipeline>, typename Dispatch = DispatchLoaderStatic> \r
+ ResultValueType<UniquePipeline>::type createComputePipelineUnique( PipelineCache pipelineCache, const ComputePipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyPipeline( Pipeline pipeline, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyPipeline( Pipeline pipeline, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Pipeline pipeline, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Pipeline pipeline, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createPipelineLayout( const PipelineLayoutCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, PipelineLayout* pPipelineLayout, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<PipelineLayout>::type createPipelineLayout( const PipelineLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniquePipelineLayout>::type createPipelineLayoutUnique( const PipelineLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyPipelineLayout( PipelineLayout pipelineLayout, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyPipelineLayout( PipelineLayout pipelineLayout, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( PipelineLayout pipelineLayout, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( PipelineLayout pipelineLayout, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createSampler( const SamplerCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Sampler* pSampler, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Sampler>::type createSampler( const SamplerCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSampler>::type createSamplerUnique( const SamplerCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySampler( Sampler sampler, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySampler( Sampler sampler, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Sampler sampler, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Sampler sampler, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDescriptorSetLayout( const DescriptorSetLayoutCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorSetLayout* pSetLayout, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DescriptorSetLayout>::type createDescriptorSetLayout( const DescriptorSetLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDescriptorSetLayout>::type createDescriptorSetLayoutUnique( const DescriptorSetLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorSetLayout( DescriptorSetLayout descriptorSetLayout, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorSetLayout( DescriptorSetLayout descriptorSetLayout, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DescriptorSetLayout descriptorSetLayout, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DescriptorSetLayout descriptorSetLayout, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDescriptorPool( const DescriptorPoolCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorPool* pDescriptorPool, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DescriptorPool>::type createDescriptorPool( const DescriptorPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDescriptorPool>::type createDescriptorPoolUnique( const DescriptorPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorPool( DescriptorPool descriptorPool, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorPool( DescriptorPool descriptorPool, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DescriptorPool descriptorPool, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DescriptorPool descriptorPool, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result resetDescriptorPool( DescriptorPool descriptorPool, DescriptorPoolResetFlags flags = DescriptorPoolResetFlags(), Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type resetDescriptorPool( DescriptorPool descriptorPool, DescriptorPoolResetFlags flags = DescriptorPoolResetFlags(), Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result allocateDescriptorSets( const DescriptorSetAllocateInfo* pAllocateInfo, DescriptorSet* pDescriptorSets, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<DescriptorSet>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<DescriptorSet,Allocator>>::type allocateDescriptorSets( const DescriptorSetAllocateInfo & allocateInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator = std::allocator<UniqueDescriptorSet>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<UniqueDescriptorSet,Allocator>>::type allocateDescriptorSetsUnique( const DescriptorSetAllocateInfo & allocateInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result freeDescriptorSets( DescriptorPool descriptorPool, uint32_t descriptorSetCount, const DescriptorSet* pDescriptorSets, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type freeDescriptorSets( DescriptorPool descriptorPool, ArrayProxy<const DescriptorSet> descriptorSets, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result free( DescriptorPool descriptorPool, uint32_t descriptorSetCount, const DescriptorSet* pDescriptorSets, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type free( DescriptorPool descriptorPool, ArrayProxy<const DescriptorSet> descriptorSets, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void updateDescriptorSets( uint32_t descriptorWriteCount, const WriteDescriptorSet* pDescriptorWrites, uint32_t descriptorCopyCount, const CopyDescriptorSet* pDescriptorCopies, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void updateDescriptorSets( ArrayProxy<const WriteDescriptorSet> descriptorWrites, ArrayProxy<const CopyDescriptorSet> descriptorCopies, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createFramebuffer( const FramebufferCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Framebuffer* pFramebuffer, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Framebuffer>::type createFramebuffer( const FramebufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueFramebuffer>::type createFramebufferUnique( const FramebufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyFramebuffer( Framebuffer framebuffer, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyFramebuffer( Framebuffer framebuffer, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Framebuffer framebuffer, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Framebuffer framebuffer, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createRenderPass( const RenderPassCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, RenderPass* pRenderPass, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<RenderPass>::type createRenderPass( const RenderPassCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueRenderPass>::type createRenderPassUnique( const RenderPassCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyRenderPass( RenderPass renderPass, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyRenderPass( RenderPass renderPass, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( RenderPass renderPass, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( RenderPass renderPass, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getRenderAreaGranularity( RenderPass renderPass, Extent2D* pGranularity, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Extent2D getRenderAreaGranularity( RenderPass renderPass, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createCommandPool( const CommandPoolCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, CommandPool* pCommandPool, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<CommandPool>::type createCommandPool( const CommandPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueCommandPool>::type createCommandPoolUnique( const CommandPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyCommandPool( CommandPool commandPool, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyCommandPool( CommandPool commandPool, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( CommandPool commandPool, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( CommandPool commandPool, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result resetCommandPool( CommandPool commandPool, CommandPoolResetFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type resetCommandPool( CommandPool commandPool, CommandPoolResetFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result allocateCommandBuffers( const CommandBufferAllocateInfo* pAllocateInfo, CommandBuffer* pCommandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<CommandBuffer>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<CommandBuffer,Allocator>>::type allocateCommandBuffers( const CommandBufferAllocateInfo & allocateInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator = std::allocator<UniqueCommandBuffer>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<UniqueCommandBuffer,Allocator>>::type allocateCommandBuffersUnique( const CommandBufferAllocateInfo & allocateInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void freeCommandBuffers( CommandPool commandPool, uint32_t commandBufferCount, const CommandBuffer* pCommandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void freeCommandBuffers( CommandPool commandPool, ArrayProxy<const CommandBuffer> commandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void free( CommandPool commandPool, uint32_t commandBufferCount, const CommandBuffer* pCommandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void free( CommandPool commandPool, ArrayProxy<const CommandBuffer> commandBuffers, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createSharedSwapchainsKHR( uint32_t swapchainCount, const SwapchainCreateInfoKHR* pCreateInfos, const AllocationCallbacks* pAllocator, SwapchainKHR* pSwapchains, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SwapchainKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<SwapchainKHR,Allocator>>::type createSharedSwapchainsKHR( ArrayProxy<const SwapchainCreateInfoKHR> createInfos, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+ template <typename Allocator = std::allocator<SwapchainKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ ResultValueType<SwapchainKHR>::type createSharedSwapchainKHR( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator = std::allocator<UniqueSwapchainKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<UniqueSwapchainKHR,Allocator>>::type createSharedSwapchainsKHRUnique( ArrayProxy<const SwapchainCreateInfoKHR> createInfos, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+ template <typename Allocator = std::allocator<UniqueSwapchainKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ ResultValueType<UniqueSwapchainKHR>::type createSharedSwapchainKHRUnique( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createSwapchainKHR( const SwapchainCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SwapchainKHR* pSwapchain, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SwapchainKHR>::type createSwapchainKHR( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSwapchainKHR>::type createSwapchainKHRUnique( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySwapchainKHR( SwapchainKHR swapchain, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySwapchainKHR( SwapchainKHR swapchain, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( SwapchainKHR swapchain, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( SwapchainKHR swapchain, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSwapchainImagesKHR( SwapchainKHR swapchain, uint32_t* pSwapchainImageCount, Image* pSwapchainImages, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<Image>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<Image,Allocator>>::type getSwapchainImagesKHR( SwapchainKHR swapchain, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result acquireNextImageKHR( SwapchainKHR swapchain, uint64_t timeout, Semaphore semaphore, Fence fence, uint32_t* pImageIndex, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValue<uint32_t> acquireNextImageKHR( SwapchainKHR swapchain, uint64_t timeout, Semaphore semaphore, Fence fence, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result debugMarkerSetObjectNameEXT( const DebugMarkerObjectNameInfoEXT* pNameInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type debugMarkerSetObjectNameEXT( const DebugMarkerObjectNameInfoEXT & nameInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result debugMarkerSetObjectTagEXT( const DebugMarkerObjectTagInfoEXT* pTagInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type debugMarkerSetObjectTagEXT( const DebugMarkerObjectTagInfoEXT & tagInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryWin32HandleNV( DeviceMemory memory, ExternalMemoryHandleTypeFlagsNV handleType, HANDLE* pHandle, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<HANDLE>::type getMemoryWin32HandleNV( DeviceMemory memory, ExternalMemoryHandleTypeFlagsNV handleType, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createIndirectCommandsLayoutNVX( const IndirectCommandsLayoutCreateInfoNVX* pCreateInfo, const AllocationCallbacks* pAllocator, IndirectCommandsLayoutNVX* pIndirectCommandsLayout, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<IndirectCommandsLayoutNVX>::type createIndirectCommandsLayoutNVX( const IndirectCommandsLayoutCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueIndirectCommandsLayoutNVX>::type createIndirectCommandsLayoutNVXUnique( const IndirectCommandsLayoutCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyIndirectCommandsLayoutNVX( IndirectCommandsLayoutNVX indirectCommandsLayout, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyIndirectCommandsLayoutNVX( IndirectCommandsLayoutNVX indirectCommandsLayout, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( IndirectCommandsLayoutNVX indirectCommandsLayout, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( IndirectCommandsLayoutNVX indirectCommandsLayout, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createObjectTableNVX( const ObjectTableCreateInfoNVX* pCreateInfo, const AllocationCallbacks* pAllocator, ObjectTableNVX* pObjectTable, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ObjectTableNVX>::type createObjectTableNVX( const ObjectTableCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueObjectTableNVX>::type createObjectTableNVXUnique( const ObjectTableCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyObjectTableNVX( ObjectTableNVX objectTable, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyObjectTableNVX( ObjectTableNVX objectTable, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ObjectTableNVX objectTable, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ObjectTableNVX objectTable, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result registerObjectsNVX( ObjectTableNVX objectTable, uint32_t objectCount, const ObjectTableEntryNVX* const* ppObjectTableEntries, const uint32_t* pObjectIndices, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type registerObjectsNVX( ObjectTableNVX objectTable, ArrayProxy<const ObjectTableEntryNVX* const> pObjectTableEntries, ArrayProxy<const uint32_t> objectIndices, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result unregisterObjectsNVX( ObjectTableNVX objectTable, uint32_t objectCount, const ObjectEntryTypeNVX* pObjectEntryTypes, const uint32_t* pObjectIndices, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type unregisterObjectsNVX( ObjectTableNVX objectTable, ArrayProxy<const ObjectEntryTypeNVX> objectEntryTypes, ArrayProxy<const uint32_t> objectIndices, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void trimCommandPool( CommandPool commandPool, CommandPoolTrimFlags flags = CommandPoolTrimFlags(), Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void trimCommandPoolKHR( CommandPool commandPool, CommandPoolTrimFlags flags = CommandPoolTrimFlags(), Dispatch const &d = Dispatch() ) const;\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryWin32HandleKHR( const MemoryGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<HANDLE>::type getMemoryWin32HandleKHR( const MemoryGetWin32HandleInfoKHR & getWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryWin32HandlePropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, HANDLE handle, MemoryWin32HandlePropertiesKHR* pMemoryWin32HandleProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<MemoryWin32HandlePropertiesKHR>::type getMemoryWin32HandlePropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, HANDLE handle, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryFdKHR( const MemoryGetFdInfoKHR* pGetFdInfo, int* pFd, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<int>::type getMemoryFdKHR( const MemoryGetFdInfoKHR & getFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryFdPropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, int fd, MemoryFdPropertiesKHR* pMemoryFdProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<MemoryFdPropertiesKHR>::type getMemoryFdPropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, int fd, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSemaphoreWin32HandleKHR( const SemaphoreGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<HANDLE>::type getSemaphoreWin32HandleKHR( const SemaphoreGetWin32HandleInfoKHR & getWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result importSemaphoreWin32HandleKHR( const ImportSemaphoreWin32HandleInfoKHR* pImportSemaphoreWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type importSemaphoreWin32HandleKHR( const ImportSemaphoreWin32HandleInfoKHR & importSemaphoreWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSemaphoreFdKHR( const SemaphoreGetFdInfoKHR* pGetFdInfo, int* pFd, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<int>::type getSemaphoreFdKHR( const SemaphoreGetFdInfoKHR & getFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result importSemaphoreFdKHR( const ImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type importSemaphoreFdKHR( const ImportSemaphoreFdInfoKHR & importSemaphoreFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getFenceWin32HandleKHR( const FenceGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<HANDLE>::type getFenceWin32HandleKHR( const FenceGetWin32HandleInfoKHR & getWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result importFenceWin32HandleKHR( const ImportFenceWin32HandleInfoKHR* pImportFenceWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type importFenceWin32HandleKHR( const ImportFenceWin32HandleInfoKHR & importFenceWin32HandleInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getFenceFdKHR( const FenceGetFdInfoKHR* pGetFdInfo, int* pFd, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<int>::type getFenceFdKHR( const FenceGetFdInfoKHR & getFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result importFenceFdKHR( const ImportFenceFdInfoKHR* pImportFenceFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type importFenceFdKHR( const ImportFenceFdInfoKHR & importFenceFdInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result displayPowerControlEXT( DisplayKHR display, const DisplayPowerInfoEXT* pDisplayPowerInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type displayPowerControlEXT( DisplayKHR display, const DisplayPowerInfoEXT & displayPowerInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result registerEventEXT( const DeviceEventInfoEXT* pDeviceEventInfo, const AllocationCallbacks* pAllocator, Fence* pFence, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Fence>::type registerEventEXT( const DeviceEventInfoEXT & deviceEventInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result registerDisplayEventEXT( DisplayKHR display, const DisplayEventInfoEXT* pDisplayEventInfo, const AllocationCallbacks* pAllocator, Fence* pFence, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Fence>::type registerDisplayEventEXT( DisplayKHR display, const DisplayEventInfoEXT & displayEventInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSwapchainCounterEXT( SwapchainKHR swapchain, SurfaceCounterFlagBitsEXT counter, uint64_t* pCounterValue, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<uint64_t>::type getSwapchainCounterEXT( SwapchainKHR swapchain, SurfaceCounterFlagBitsEXT counter, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getGroupPeerMemoryFeatures( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, PeerMemoryFeatureFlags* pPeerMemoryFeatures, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PeerMemoryFeatureFlags getGroupPeerMemoryFeatures( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getGroupPeerMemoryFeaturesKHR( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, PeerMemoryFeatureFlags* pPeerMemoryFeatures, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PeerMemoryFeatureFlags getGroupPeerMemoryFeaturesKHR( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindBufferMemory2( uint32_t bindInfoCount, const BindBufferMemoryInfo* pBindInfos, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindBufferMemory2( ArrayProxy<const BindBufferMemoryInfo> bindInfos, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindBufferMemory2KHR( uint32_t bindInfoCount, const BindBufferMemoryInfo* pBindInfos, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindBufferMemory2KHR( ArrayProxy<const BindBufferMemoryInfo> bindInfos, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindImageMemory2( uint32_t bindInfoCount, const BindImageMemoryInfo* pBindInfos, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindImageMemory2( ArrayProxy<const BindImageMemoryInfo> bindInfos, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result bindImageMemory2KHR( uint32_t bindInfoCount, const BindImageMemoryInfo* pBindInfos, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type bindImageMemory2KHR( ArrayProxy<const BindImageMemoryInfo> bindInfos, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getGroupPresentCapabilitiesKHR( DeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DeviceGroupPresentCapabilitiesKHR>::type getGroupPresentCapabilitiesKHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getGroupSurfacePresentModesKHR( SurfaceKHR surface, DeviceGroupPresentModeFlagsKHR* pModes, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DeviceGroupPresentModeFlagsKHR>::type getGroupSurfacePresentModesKHR( SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result acquireNextImage2KHR( const AcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValue<uint32_t> acquireNextImage2KHR( const AcquireNextImageInfoKHR & acquireInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDescriptorUpdateTemplate( const DescriptorUpdateTemplateCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorUpdateTemplate* pDescriptorUpdateTemplate, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DescriptorUpdateTemplate>::type createDescriptorUpdateTemplate( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDescriptorUpdateTemplate>::type createDescriptorUpdateTemplateUnique( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDescriptorUpdateTemplateKHR( const DescriptorUpdateTemplateCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorUpdateTemplate* pDescriptorUpdateTemplate, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DescriptorUpdateTemplate>::type createDescriptorUpdateTemplateKHR( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDescriptorUpdateTemplate>::type createDescriptorUpdateTemplateKHRUnique( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorUpdateTemplate( DescriptorUpdateTemplate descriptorUpdateTemplate, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorUpdateTemplate( DescriptorUpdateTemplate descriptorUpdateTemplate, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DescriptorUpdateTemplate descriptorUpdateTemplate, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DescriptorUpdateTemplate descriptorUpdateTemplate, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorUpdateTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDescriptorUpdateTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void updateDescriptorSetWithTemplate( DescriptorSet descriptorSet, DescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void updateDescriptorSetWithTemplateKHR( DescriptorSet descriptorSet, DescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setHdrMetadataEXT( uint32_t swapchainCount, const SwapchainKHR* pSwapchains, const HdrMetadataEXT* pMetadata, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void setHdrMetadataEXT( ArrayProxy<const SwapchainKHR> swapchains, ArrayProxy<const HdrMetadataEXT> metadata, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSwapchainStatusKHR( SwapchainKHR swapchain, Dispatch const &d = Dispatch() ) const;\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getRefreshCycleDurationGOOGLE( SwapchainKHR swapchain, RefreshCycleDurationGOOGLE* pDisplayTimingProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<RefreshCycleDurationGOOGLE>::type getRefreshCycleDurationGOOGLE( SwapchainKHR swapchain, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getPastPresentationTimingGOOGLE( SwapchainKHR swapchain, uint32_t* pPresentationTimingCount, PastPresentationTimingGOOGLE* pPresentationTimings, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<PastPresentationTimingGOOGLE>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<PastPresentationTimingGOOGLE,Allocator>>::type getPastPresentationTimingGOOGLE( SwapchainKHR swapchain, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getBufferMemoryRequirements2( const BufferMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MemoryRequirements2 getBufferMemoryRequirements2( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getBufferMemoryRequirements2( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getBufferMemoryRequirements2KHR( const BufferMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MemoryRequirements2 getBufferMemoryRequirements2KHR( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getBufferMemoryRequirements2KHR( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageMemoryRequirements2( const ImageMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MemoryRequirements2 getImageMemoryRequirements2( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getImageMemoryRequirements2( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageMemoryRequirements2KHR( const ImageMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MemoryRequirements2 getImageMemoryRequirements2KHR( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getImageMemoryRequirements2KHR( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageSparseMemoryRequirements2( const ImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, SparseImageMemoryRequirements2* pSparseMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SparseImageMemoryRequirements2>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<SparseImageMemoryRequirements2,Allocator> getImageSparseMemoryRequirements2( const ImageSparseMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getImageSparseMemoryRequirements2KHR( const ImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, SparseImageMemoryRequirements2* pSparseMemoryRequirements, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SparseImageMemoryRequirements2>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<SparseImageMemoryRequirements2,Allocator> getImageSparseMemoryRequirements2KHR( const ImageSparseMemoryRequirementsInfo2 & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createSamplerYcbcrConversion( const SamplerYcbcrConversionCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, SamplerYcbcrConversion* pYcbcrConversion, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SamplerYcbcrConversion>::type createSamplerYcbcrConversion( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSamplerYcbcrConversion>::type createSamplerYcbcrConversionUnique( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createSamplerYcbcrConversionKHR( const SamplerYcbcrConversionCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, SamplerYcbcrConversion* pYcbcrConversion, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SamplerYcbcrConversion>::type createSamplerYcbcrConversionKHR( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSamplerYcbcrConversion>::type createSamplerYcbcrConversionKHRUnique( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySamplerYcbcrConversion( SamplerYcbcrConversion ycbcrConversion, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySamplerYcbcrConversion( SamplerYcbcrConversion ycbcrConversion, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( SamplerYcbcrConversion ycbcrConversion, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( SamplerYcbcrConversion ycbcrConversion, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySamplerYcbcrConversionKHR( SamplerYcbcrConversion ycbcrConversion, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySamplerYcbcrConversionKHR( SamplerYcbcrConversion ycbcrConversion, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getQueue2( const DeviceQueueInfo2* pQueueInfo, Queue* pQueue, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Queue getQueue2( const DeviceQueueInfo2 & queueInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createValidationCacheEXT( const ValidationCacheCreateInfoEXT* pCreateInfo, const AllocationCallbacks* pAllocator, ValidationCacheEXT* pValidationCache, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ValidationCacheEXT>::type createValidationCacheEXT( const ValidationCacheCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueValidationCacheEXT>::type createValidationCacheEXTUnique( const ValidationCacheCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyValidationCacheEXT( ValidationCacheEXT validationCache, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyValidationCacheEXT( ValidationCacheEXT validationCache, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ValidationCacheEXT validationCache, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( ValidationCacheEXT validationCache, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getValidationCacheDataEXT( ValidationCacheEXT validationCache, size_t* pDataSize, void* pData, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<uint8_t>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<uint8_t,Allocator>>::type getValidationCacheDataEXT( ValidationCacheEXT validationCache, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result mergeValidationCachesEXT( ValidationCacheEXT dstCache, uint32_t srcCacheCount, const ValidationCacheEXT* pSrcCaches, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type mergeValidationCachesEXT( ValidationCacheEXT dstCache, ArrayProxy<const ValidationCacheEXT> srcCaches, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getDescriptorSetLayoutSupport( const DescriptorSetLayoutCreateInfo* pCreateInfo, DescriptorSetLayoutSupport* pSupport, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ DescriptorSetLayoutSupport getDescriptorSetLayoutSupport( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getDescriptorSetLayoutSupport( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getDescriptorSetLayoutSupportKHR( const DescriptorSetLayoutCreateInfo* pCreateInfo, DescriptorSetLayoutSupport* pSupport, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ DescriptorSetLayoutSupport getDescriptorSetLayoutSupportKHR( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getDescriptorSetLayoutSupportKHR( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getShaderInfoAMD( Pipeline pipeline, ShaderStageFlagBits shaderStage, ShaderInfoTypeAMD infoType, size_t* pInfoSize, void* pInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<uint8_t>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<uint8_t,Allocator>>::type getShaderInfoAMD( Pipeline pipeline, ShaderStageFlagBits shaderStage, ShaderInfoTypeAMD infoType, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result setDebugUtilsObjectNameEXT( const DebugUtilsObjectNameInfoEXT* pNameInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type setDebugUtilsObjectNameEXT( const DebugUtilsObjectNameInfoEXT & nameInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result setDebugUtilsObjectTagEXT( const DebugUtilsObjectTagInfoEXT* pTagInfo, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type setDebugUtilsObjectTagEXT( const DebugUtilsObjectTagInfoEXT & tagInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryHostPointerPropertiesEXT( ExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, MemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<MemoryHostPointerPropertiesEXT>::type getMemoryHostPointerPropertiesEXT( ExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getAndroidHardwareBufferPropertiesANDROID( const struct AHardwareBuffer* buffer, AndroidHardwareBufferPropertiesANDROID* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<AndroidHardwareBufferPropertiesANDROID>::type getAndroidHardwareBufferPropertiesANDROID( const struct AHardwareBuffer & buffer, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ typename ResultValueType<StructureChain<T...>>::type getAndroidHardwareBufferPropertiesANDROID( const struct AHardwareBuffer & buffer, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getMemoryAndroidHardwareBufferANDROID( const MemoryGetAndroidHardwareBufferInfoANDROID* pInfo, struct AHardwareBuffer** pBuffer, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<struct AHardwareBuffer*>::type getMemoryAndroidHardwareBufferANDROID( const MemoryGetAndroidHardwareBufferInfoANDROID & info, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkDevice() const\r
+ {\r
+ return m_device;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_device != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_device == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkDevice m_device;\r
+ };\r
+\r
+ static_assert( sizeof( Device ) == sizeof( VkDevice ), "handle and wrapper have different size!" );\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PFN_vkVoidFunction Device::getProcAddr( const char* pName, Dispatch const &d) const\r
+ {\r
+ return d.vkGetDeviceProcAddr( m_device, pName );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PFN_vkVoidFunction Device::getProcAddr( const std::string & name, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetDeviceProcAddr( m_device, name.c_str() );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDevice( m_device, reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDevice( m_device, reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getQueue( uint32_t queueFamilyIndex, uint32_t queueIndex, Queue* pQueue, Dispatch const &d) const\r
+ {\r
+ d.vkGetDeviceQueue( m_device, queueFamilyIndex, queueIndex, reinterpret_cast<VkQueue*>( pQueue ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Queue Device::getQueue( uint32_t queueFamilyIndex, uint32_t queueIndex, Dispatch const &d ) const\r
+ {\r
+ Queue queue;\r
+ d.vkGetDeviceQueue( m_device, queueFamilyIndex, queueIndex, reinterpret_cast<VkQueue*>( &queue ) );\r
+ return queue;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::waitIdle(Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkDeviceWaitIdle( m_device ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::waitIdle(Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkDeviceWaitIdle( m_device ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::waitIdle" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::allocateMemory( const MemoryAllocateInfo* pAllocateInfo, const AllocationCallbacks* pAllocator, DeviceMemory* pMemory, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkAllocateMemory( m_device, reinterpret_cast<const VkMemoryAllocateInfo*>( pAllocateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDeviceMemory*>( pMemory ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DeviceMemory>::type Device::allocateMemory( const MemoryAllocateInfo & allocateInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DeviceMemory memory;\r
+ Result result = static_cast<Result>( d.vkAllocateMemory( m_device, reinterpret_cast<const VkMemoryAllocateInfo*>( &allocateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDeviceMemory*>( &memory ) ) );\r
+ return createResultValue( result, memory, VULKAN_HPP_NAMESPACE_STRING"::Device::allocateMemory" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDeviceMemory>::type Device::allocateMemoryUnique( const MemoryAllocateInfo & allocateInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DeviceMemory memory;\r
+ Result result = static_cast<Result>( d.vkAllocateMemory( m_device, reinterpret_cast<const VkMemoryAllocateInfo*>( &allocateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDeviceMemory*>( &memory ) ) );\r
+\r
+ ObjectFree<Device> deleter( *this, allocator );\r
+ return createResultValue( result, memory, VULKAN_HPP_NAMESPACE_STRING"::Device::allocateMemoryUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::freeMemory( DeviceMemory memory, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkFreeMemory( m_device, static_cast<VkDeviceMemory>( memory ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::freeMemory( DeviceMemory memory, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkFreeMemory( m_device, static_cast<VkDeviceMemory>( memory ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::free( DeviceMemory memory, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkFreeMemory( m_device, static_cast<VkDeviceMemory>( memory ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::free( DeviceMemory memory, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkFreeMemory( m_device, static_cast<VkDeviceMemory>( memory ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::mapMemory( DeviceMemory memory, DeviceSize offset, DeviceSize size, MemoryMapFlags flags, void** ppData, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkMapMemory( m_device, static_cast<VkDeviceMemory>( memory ), offset, size, static_cast<VkMemoryMapFlags>( flags ), ppData ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void*>::type Device::mapMemory( DeviceMemory memory, DeviceSize offset, DeviceSize size, MemoryMapFlags flags, Dispatch const &d ) const\r
+ {\r
+ void* pData;\r
+ Result result = static_cast<Result>( d.vkMapMemory( m_device, static_cast<VkDeviceMemory>( memory ), offset, size, static_cast<VkMemoryMapFlags>( flags ), &pData ) );\r
+ return createResultValue( result, pData, VULKAN_HPP_NAMESPACE_STRING"::Device::mapMemory" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::unmapMemory( DeviceMemory memory, Dispatch const &d) const\r
+ {\r
+ d.vkUnmapMemory( m_device, static_cast<VkDeviceMemory>( memory ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::unmapMemory( DeviceMemory memory, Dispatch const &d ) const\r
+ {\r
+ d.vkUnmapMemory( m_device, static_cast<VkDeviceMemory>( memory ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::flushMappedMemoryRanges( uint32_t memoryRangeCount, const MappedMemoryRange* pMemoryRanges, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkFlushMappedMemoryRanges( m_device, memoryRangeCount, reinterpret_cast<const VkMappedMemoryRange*>( pMemoryRanges ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::flushMappedMemoryRanges( ArrayProxy<const MappedMemoryRange> memoryRanges, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkFlushMappedMemoryRanges( m_device, memoryRanges.size() , reinterpret_cast<const VkMappedMemoryRange*>( memoryRanges.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::flushMappedMemoryRanges" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::invalidateMappedMemoryRanges( uint32_t memoryRangeCount, const MappedMemoryRange* pMemoryRanges, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkInvalidateMappedMemoryRanges( m_device, memoryRangeCount, reinterpret_cast<const VkMappedMemoryRange*>( pMemoryRanges ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::invalidateMappedMemoryRanges( ArrayProxy<const MappedMemoryRange> memoryRanges, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkInvalidateMappedMemoryRanges( m_device, memoryRanges.size() , reinterpret_cast<const VkMappedMemoryRange*>( memoryRanges.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::invalidateMappedMemoryRanges" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getMemoryCommitment( DeviceMemory memory, DeviceSize* pCommittedMemoryInBytes, Dispatch const &d) const\r
+ {\r
+ d.vkGetDeviceMemoryCommitment( m_device, static_cast<VkDeviceMemory>( memory ), pCommittedMemoryInBytes );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE DeviceSize Device::getMemoryCommitment( DeviceMemory memory, Dispatch const &d ) const\r
+ {\r
+ DeviceSize committedMemoryInBytes;\r
+ d.vkGetDeviceMemoryCommitment( m_device, static_cast<VkDeviceMemory>( memory ), &committedMemoryInBytes );\r
+ return committedMemoryInBytes;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getBufferMemoryRequirements( Buffer buffer, MemoryRequirements* pMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetBufferMemoryRequirements( m_device, static_cast<VkBuffer>( buffer ), reinterpret_cast<VkMemoryRequirements*>( pMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MemoryRequirements Device::getBufferMemoryRequirements( Buffer buffer, Dispatch const &d ) const\r
+ {\r
+ MemoryRequirements memoryRequirements;\r
+ d.vkGetBufferMemoryRequirements( m_device, static_cast<VkBuffer>( buffer ), reinterpret_cast<VkMemoryRequirements*>( &memoryRequirements ) );\r
+ return memoryRequirements;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::bindBufferMemory( Buffer buffer, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBindBufferMemory( m_device, static_cast<VkBuffer>( buffer ), static_cast<VkDeviceMemory>( memory ), memoryOffset ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::bindBufferMemory( Buffer buffer, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBindBufferMemory( m_device, static_cast<VkBuffer>( buffer ), static_cast<VkDeviceMemory>( memory ), memoryOffset ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::bindBufferMemory" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageMemoryRequirements( Image image, MemoryRequirements* pMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageMemoryRequirements( m_device, static_cast<VkImage>( image ), reinterpret_cast<VkMemoryRequirements*>( pMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MemoryRequirements Device::getImageMemoryRequirements( Image image, Dispatch const &d ) const\r
+ {\r
+ MemoryRequirements memoryRequirements;\r
+ d.vkGetImageMemoryRequirements( m_device, static_cast<VkImage>( image ), reinterpret_cast<VkMemoryRequirements*>( &memoryRequirements ) );\r
+ return memoryRequirements;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::bindImageMemory( Image image, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBindImageMemory( m_device, static_cast<VkImage>( image ), static_cast<VkDeviceMemory>( memory ), memoryOffset ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::bindImageMemory( Image image, DeviceMemory memory, DeviceSize memoryOffset, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBindImageMemory( m_device, static_cast<VkImage>( image ), static_cast<VkDeviceMemory>( memory ), memoryOffset ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::bindImageMemory" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageSparseMemoryRequirements( Image image, uint32_t* pSparseMemoryRequirementCount, SparseImageMemoryRequirements* pSparseMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageSparseMemoryRequirements( m_device, static_cast<VkImage>( image ), pSparseMemoryRequirementCount, reinterpret_cast<VkSparseImageMemoryRequirements*>( pSparseMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<SparseImageMemoryRequirements,Allocator> Device::getImageSparseMemoryRequirements( Image image, Dispatch const &d ) const\r
+ {\r
+ std::vector<SparseImageMemoryRequirements,Allocator> sparseMemoryRequirements;\r
+ uint32_t sparseMemoryRequirementCount;\r
+ d.vkGetImageSparseMemoryRequirements( m_device, static_cast<VkImage>( image ), &sparseMemoryRequirementCount, nullptr );\r
+ sparseMemoryRequirements.resize( sparseMemoryRequirementCount );\r
+ d.vkGetImageSparseMemoryRequirements( m_device, static_cast<VkImage>( image ), &sparseMemoryRequirementCount, reinterpret_cast<VkSparseImageMemoryRequirements*>( sparseMemoryRequirements.data() ) );\r
+ return sparseMemoryRequirements;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createFence( const FenceCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Fence* pFence, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateFence( m_device, reinterpret_cast<const VkFenceCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkFence*>( pFence ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Fence>::type Device::createFence( const FenceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Fence fence;\r
+ Result result = static_cast<Result>( d.vkCreateFence( m_device, reinterpret_cast<const VkFenceCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkFence*>( &fence ) ) );\r
+ return createResultValue( result, fence, VULKAN_HPP_NAMESPACE_STRING"::Device::createFence" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueFence>::type Device::createFenceUnique( const FenceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Fence fence;\r
+ Result result = static_cast<Result>( d.vkCreateFence( m_device, reinterpret_cast<const VkFenceCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkFence*>( &fence ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, fence, VULKAN_HPP_NAMESPACE_STRING"::Device::createFenceUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyFence( Fence fence, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyFence( m_device, static_cast<VkFence>( fence ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyFence( Fence fence, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyFence( m_device, static_cast<VkFence>( fence ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Fence fence, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyFence( m_device, static_cast<VkFence>( fence ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Fence fence, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyFence( m_device, static_cast<VkFence>( fence ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::resetFences( uint32_t fenceCount, const Fence* pFences, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkResetFences( m_device, fenceCount, reinterpret_cast<const VkFence*>( pFences ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::resetFences( ArrayProxy<const Fence> fences, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkResetFences( m_device, fences.size() , reinterpret_cast<const VkFence*>( fences.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::resetFences" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getFenceStatus( Fence fence, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetFenceStatus( m_device, static_cast<VkFence>( fence ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getFenceStatus( Fence fence, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkGetFenceStatus( m_device, static_cast<VkFence>( fence ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::getFenceStatus", { Result::eSuccess, Result::eNotReady } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::waitForFences( uint32_t fenceCount, const Fence* pFences, Bool32 waitAll, uint64_t timeout, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkWaitForFences( m_device, fenceCount, reinterpret_cast<const VkFence*>( pFences ), waitAll, timeout ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::waitForFences( ArrayProxy<const Fence> fences, Bool32 waitAll, uint64_t timeout, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkWaitForFences( m_device, fences.size() , reinterpret_cast<const VkFence*>( fences.data() ), waitAll, timeout ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::waitForFences", { Result::eSuccess, Result::eTimeout } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createSemaphore( const SemaphoreCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Semaphore* pSemaphore, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateSemaphore( m_device, reinterpret_cast<const VkSemaphoreCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSemaphore*>( pSemaphore ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Semaphore>::type Device::createSemaphore( const SemaphoreCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Semaphore semaphore;\r
+ Result result = static_cast<Result>( d.vkCreateSemaphore( m_device, reinterpret_cast<const VkSemaphoreCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSemaphore*>( &semaphore ) ) );\r
+ return createResultValue( result, semaphore, VULKAN_HPP_NAMESPACE_STRING"::Device::createSemaphore" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSemaphore>::type Device::createSemaphoreUnique( const SemaphoreCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Semaphore semaphore;\r
+ Result result = static_cast<Result>( d.vkCreateSemaphore( m_device, reinterpret_cast<const VkSemaphoreCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSemaphore*>( &semaphore ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, semaphore, VULKAN_HPP_NAMESPACE_STRING"::Device::createSemaphoreUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySemaphore( Semaphore semaphore, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySemaphore( m_device, static_cast<VkSemaphore>( semaphore ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySemaphore( Semaphore semaphore, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySemaphore( m_device, static_cast<VkSemaphore>( semaphore ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Semaphore semaphore, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySemaphore( m_device, static_cast<VkSemaphore>( semaphore ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Semaphore semaphore, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySemaphore( m_device, static_cast<VkSemaphore>( semaphore ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createEvent( const EventCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Event* pEvent, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateEvent( m_device, reinterpret_cast<const VkEventCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkEvent*>( pEvent ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Event>::type Device::createEvent( const EventCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Event event;\r
+ Result result = static_cast<Result>( d.vkCreateEvent( m_device, reinterpret_cast<const VkEventCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkEvent*>( &event ) ) );\r
+ return createResultValue( result, event, VULKAN_HPP_NAMESPACE_STRING"::Device::createEvent" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueEvent>::type Device::createEventUnique( const EventCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Event event;\r
+ Result result = static_cast<Result>( d.vkCreateEvent( m_device, reinterpret_cast<const VkEventCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkEvent*>( &event ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, event, VULKAN_HPP_NAMESPACE_STRING"::Device::createEventUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyEvent( Event event, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyEvent( m_device, static_cast<VkEvent>( event ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyEvent( Event event, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyEvent( m_device, static_cast<VkEvent>( event ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Event event, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyEvent( m_device, static_cast<VkEvent>( event ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Event event, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyEvent( m_device, static_cast<VkEvent>( event ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getEventStatus( Event event, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetEventStatus( m_device, static_cast<VkEvent>( event ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getEventStatus( Event event, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkGetEventStatus( m_device, static_cast<VkEvent>( event ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::getEventStatus", { Result::eEventSet, Result::eEventReset } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::setEvent( Event event, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkSetEvent( m_device, static_cast<VkEvent>( event ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::setEvent( Event event, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkSetEvent( m_device, static_cast<VkEvent>( event ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::setEvent" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::resetEvent( Event event, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkResetEvent( m_device, static_cast<VkEvent>( event ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::resetEvent( Event event, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkResetEvent( m_device, static_cast<VkEvent>( event ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::resetEvent" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createQueryPool( const QueryPoolCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, QueryPool* pQueryPool, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateQueryPool( m_device, reinterpret_cast<const VkQueryPoolCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkQueryPool*>( pQueryPool ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<QueryPool>::type Device::createQueryPool( const QueryPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ QueryPool queryPool;\r
+ Result result = static_cast<Result>( d.vkCreateQueryPool( m_device, reinterpret_cast<const VkQueryPoolCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkQueryPool*>( &queryPool ) ) );\r
+ return createResultValue( result, queryPool, VULKAN_HPP_NAMESPACE_STRING"::Device::createQueryPool" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueQueryPool>::type Device::createQueryPoolUnique( const QueryPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ QueryPool queryPool;\r
+ Result result = static_cast<Result>( d.vkCreateQueryPool( m_device, reinterpret_cast<const VkQueryPoolCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkQueryPool*>( &queryPool ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, queryPool, VULKAN_HPP_NAMESPACE_STRING"::Device::createQueryPoolUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyQueryPool( QueryPool queryPool, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyQueryPool( m_device, static_cast<VkQueryPool>( queryPool ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyQueryPool( QueryPool queryPool, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyQueryPool( m_device, static_cast<VkQueryPool>( queryPool ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( QueryPool queryPool, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyQueryPool( m_device, static_cast<VkQueryPool>( queryPool ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( QueryPool queryPool, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyQueryPool( m_device, static_cast<VkQueryPool>( queryPool ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, size_t dataSize, void* pData, DeviceSize stride, QueryResultFlags flags, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetQueryPoolResults( m_device, static_cast<VkQueryPool>( queryPool ), firstQuery, queryCount, dataSize, pData, stride, static_cast<VkQueryResultFlags>( flags ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename T, typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getQueryPoolResults( QueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, ArrayProxy<T> data, DeviceSize stride, QueryResultFlags flags, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkGetQueryPoolResults( m_device, static_cast<VkQueryPool>( queryPool ), firstQuery, queryCount, data.size() * sizeof( T ) , reinterpret_cast<void*>( data.data() ), stride, static_cast<VkQueryResultFlags>( flags ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::getQueryPoolResults", { Result::eSuccess, Result::eNotReady } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createBuffer( const BufferCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Buffer* pBuffer, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateBuffer( m_device, reinterpret_cast<const VkBufferCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkBuffer*>( pBuffer ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Buffer>::type Device::createBuffer( const BufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Buffer buffer;\r
+ Result result = static_cast<Result>( d.vkCreateBuffer( m_device, reinterpret_cast<const VkBufferCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkBuffer*>( &buffer ) ) );\r
+ return createResultValue( result, buffer, VULKAN_HPP_NAMESPACE_STRING"::Device::createBuffer" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueBuffer>::type Device::createBufferUnique( const BufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Buffer buffer;\r
+ Result result = static_cast<Result>( d.vkCreateBuffer( m_device, reinterpret_cast<const VkBufferCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkBuffer*>( &buffer ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, buffer, VULKAN_HPP_NAMESPACE_STRING"::Device::createBufferUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyBuffer( Buffer buffer, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyBuffer( m_device, static_cast<VkBuffer>( buffer ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyBuffer( Buffer buffer, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyBuffer( m_device, static_cast<VkBuffer>( buffer ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Buffer buffer, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyBuffer( m_device, static_cast<VkBuffer>( buffer ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Buffer buffer, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyBuffer( m_device, static_cast<VkBuffer>( buffer ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createBufferView( const BufferViewCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, BufferView* pView, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateBufferView( m_device, reinterpret_cast<const VkBufferViewCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkBufferView*>( pView ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<BufferView>::type Device::createBufferView( const BufferViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ BufferView view;\r
+ Result result = static_cast<Result>( d.vkCreateBufferView( m_device, reinterpret_cast<const VkBufferViewCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkBufferView*>( &view ) ) );\r
+ return createResultValue( result, view, VULKAN_HPP_NAMESPACE_STRING"::Device::createBufferView" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueBufferView>::type Device::createBufferViewUnique( const BufferViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ BufferView view;\r
+ Result result = static_cast<Result>( d.vkCreateBufferView( m_device, reinterpret_cast<const VkBufferViewCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkBufferView*>( &view ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, view, VULKAN_HPP_NAMESPACE_STRING"::Device::createBufferViewUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyBufferView( BufferView bufferView, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyBufferView( m_device, static_cast<VkBufferView>( bufferView ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyBufferView( BufferView bufferView, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyBufferView( m_device, static_cast<VkBufferView>( bufferView ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( BufferView bufferView, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyBufferView( m_device, static_cast<VkBufferView>( bufferView ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( BufferView bufferView, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyBufferView( m_device, static_cast<VkBufferView>( bufferView ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createImage( const ImageCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Image* pImage, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateImage( m_device, reinterpret_cast<const VkImageCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkImage*>( pImage ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Image>::type Device::createImage( const ImageCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Image image;\r
+ Result result = static_cast<Result>( d.vkCreateImage( m_device, reinterpret_cast<const VkImageCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkImage*>( &image ) ) );\r
+ return createResultValue( result, image, VULKAN_HPP_NAMESPACE_STRING"::Device::createImage" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueImage>::type Device::createImageUnique( const ImageCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Image image;\r
+ Result result = static_cast<Result>( d.vkCreateImage( m_device, reinterpret_cast<const VkImageCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkImage*>( &image ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, image, VULKAN_HPP_NAMESPACE_STRING"::Device::createImageUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyImage( Image image, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyImage( m_device, static_cast<VkImage>( image ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyImage( Image image, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyImage( m_device, static_cast<VkImage>( image ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Image image, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyImage( m_device, static_cast<VkImage>( image ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Image image, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyImage( m_device, static_cast<VkImage>( image ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageSubresourceLayout( Image image, const ImageSubresource* pSubresource, SubresourceLayout* pLayout, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageSubresourceLayout( m_device, static_cast<VkImage>( image ), reinterpret_cast<const VkImageSubresource*>( pSubresource ), reinterpret_cast<VkSubresourceLayout*>( pLayout ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE SubresourceLayout Device::getImageSubresourceLayout( Image image, const ImageSubresource & subresource, Dispatch const &d ) const\r
+ {\r
+ SubresourceLayout layout;\r
+ d.vkGetImageSubresourceLayout( m_device, static_cast<VkImage>( image ), reinterpret_cast<const VkImageSubresource*>( &subresource ), reinterpret_cast<VkSubresourceLayout*>( &layout ) );\r
+ return layout;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createImageView( const ImageViewCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, ImageView* pView, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateImageView( m_device, reinterpret_cast<const VkImageViewCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkImageView*>( pView ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ImageView>::type Device::createImageView( const ImageViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ImageView view;\r
+ Result result = static_cast<Result>( d.vkCreateImageView( m_device, reinterpret_cast<const VkImageViewCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkImageView*>( &view ) ) );\r
+ return createResultValue( result, view, VULKAN_HPP_NAMESPACE_STRING"::Device::createImageView" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueImageView>::type Device::createImageViewUnique( const ImageViewCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ImageView view;\r
+ Result result = static_cast<Result>( d.vkCreateImageView( m_device, reinterpret_cast<const VkImageViewCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkImageView*>( &view ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, view, VULKAN_HPP_NAMESPACE_STRING"::Device::createImageViewUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyImageView( ImageView imageView, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyImageView( m_device, static_cast<VkImageView>( imageView ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyImageView( ImageView imageView, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyImageView( m_device, static_cast<VkImageView>( imageView ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ImageView imageView, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyImageView( m_device, static_cast<VkImageView>( imageView ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ImageView imageView, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyImageView( m_device, static_cast<VkImageView>( imageView ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createShaderModule( const ShaderModuleCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, ShaderModule* pShaderModule, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateShaderModule( m_device, reinterpret_cast<const VkShaderModuleCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkShaderModule*>( pShaderModule ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ShaderModule>::type Device::createShaderModule( const ShaderModuleCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ShaderModule shaderModule;\r
+ Result result = static_cast<Result>( d.vkCreateShaderModule( m_device, reinterpret_cast<const VkShaderModuleCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkShaderModule*>( &shaderModule ) ) );\r
+ return createResultValue( result, shaderModule, VULKAN_HPP_NAMESPACE_STRING"::Device::createShaderModule" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueShaderModule>::type Device::createShaderModuleUnique( const ShaderModuleCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ShaderModule shaderModule;\r
+ Result result = static_cast<Result>( d.vkCreateShaderModule( m_device, reinterpret_cast<const VkShaderModuleCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkShaderModule*>( &shaderModule ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, shaderModule, VULKAN_HPP_NAMESPACE_STRING"::Device::createShaderModuleUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyShaderModule( ShaderModule shaderModule, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyShaderModule( m_device, static_cast<VkShaderModule>( shaderModule ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyShaderModule( ShaderModule shaderModule, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyShaderModule( m_device, static_cast<VkShaderModule>( shaderModule ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ShaderModule shaderModule, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyShaderModule( m_device, static_cast<VkShaderModule>( shaderModule ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ShaderModule shaderModule, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyShaderModule( m_device, static_cast<VkShaderModule>( shaderModule ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createPipelineCache( const PipelineCacheCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, PipelineCache* pPipelineCache, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreatePipelineCache( m_device, reinterpret_cast<const VkPipelineCacheCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkPipelineCache*>( pPipelineCache ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<PipelineCache>::type Device::createPipelineCache( const PipelineCacheCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ PipelineCache pipelineCache;\r
+ Result result = static_cast<Result>( d.vkCreatePipelineCache( m_device, reinterpret_cast<const VkPipelineCacheCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipelineCache*>( &pipelineCache ) ) );\r
+ return createResultValue( result, pipelineCache, VULKAN_HPP_NAMESPACE_STRING"::Device::createPipelineCache" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniquePipelineCache>::type Device::createPipelineCacheUnique( const PipelineCacheCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ PipelineCache pipelineCache;\r
+ Result result = static_cast<Result>( d.vkCreatePipelineCache( m_device, reinterpret_cast<const VkPipelineCacheCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipelineCache*>( &pipelineCache ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, pipelineCache, VULKAN_HPP_NAMESPACE_STRING"::Device::createPipelineCacheUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyPipelineCache( PipelineCache pipelineCache, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyPipelineCache( m_device, static_cast<VkPipelineCache>( pipelineCache ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyPipelineCache( PipelineCache pipelineCache, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyPipelineCache( m_device, static_cast<VkPipelineCache>( pipelineCache ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( PipelineCache pipelineCache, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyPipelineCache( m_device, static_cast<VkPipelineCache>( pipelineCache ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( PipelineCache pipelineCache, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyPipelineCache( m_device, static_cast<VkPipelineCache>( pipelineCache ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getPipelineCacheData( PipelineCache pipelineCache, size_t* pDataSize, void* pData, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPipelineCacheData( m_device, static_cast<VkPipelineCache>( pipelineCache ), pDataSize, pData ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<uint8_t,Allocator>>::type Device::getPipelineCacheData( PipelineCache pipelineCache, Dispatch const &d ) const\r
+ {\r
+ std::vector<uint8_t,Allocator> data;\r
+ size_t dataSize;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPipelineCacheData( m_device, static_cast<VkPipelineCache>( pipelineCache ), &dataSize, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && dataSize )\r
+ {\r
+ data.resize( dataSize );\r
+ result = static_cast<Result>( d.vkGetPipelineCacheData( m_device, static_cast<VkPipelineCache>( pipelineCache ), &dataSize, reinterpret_cast<void*>( data.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( dataSize <= data.size() );\r
+ data.resize( dataSize );\r
+ return createResultValue( result, data, VULKAN_HPP_NAMESPACE_STRING"::Device::getPipelineCacheData" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::mergePipelineCaches( PipelineCache dstCache, uint32_t srcCacheCount, const PipelineCache* pSrcCaches, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkMergePipelineCaches( m_device, static_cast<VkPipelineCache>( dstCache ), srcCacheCount, reinterpret_cast<const VkPipelineCache*>( pSrcCaches ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::mergePipelineCaches( PipelineCache dstCache, ArrayProxy<const PipelineCache> srcCaches, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkMergePipelineCaches( m_device, static_cast<VkPipelineCache>( dstCache ), srcCaches.size() , reinterpret_cast<const VkPipelineCache*>( srcCaches.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::mergePipelineCaches" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createGraphicsPipelines( PipelineCache pipelineCache, uint32_t createInfoCount, const GraphicsPipelineCreateInfo* pCreateInfos, const AllocationCallbacks* pAllocator, Pipeline* pPipelines, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateGraphicsPipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), createInfoCount, reinterpret_cast<const VkGraphicsPipelineCreateInfo*>( pCreateInfos ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkPipeline*>( pPipelines ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<Pipeline,Allocator>>::type Device::createGraphicsPipelines( PipelineCache pipelineCache, ArrayProxy<const GraphicsPipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ std::vector<Pipeline,Allocator> pipelines( createInfos.size() );\r
+ Result result = static_cast<Result>( d.vkCreateGraphicsPipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), createInfos.size() , reinterpret_cast<const VkGraphicsPipelineCreateInfo*>( createInfos.data() ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( pipelines.data() ) ) );\r
+ return createResultValue( result, pipelines, VULKAN_HPP_NAMESPACE_STRING"::Device::createGraphicsPipelines" );\r
+ }\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE ResultValueType<Pipeline>::type Device::createGraphicsPipeline( PipelineCache pipelineCache, const GraphicsPipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Pipeline pipeline;\r
+ Result result = static_cast<Result>( d.vkCreateGraphicsPipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), 1 , reinterpret_cast<const VkGraphicsPipelineCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( &pipeline ) ) );\r
+ return createResultValue( result, pipeline, VULKAN_HPP_NAMESPACE_STRING"::Device::createGraphicsPipeline" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<UniquePipeline,Allocator>>::type Device::createGraphicsPipelinesUnique( PipelineCache pipelineCache, ArrayProxy<const GraphicsPipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ static_assert( sizeof( Pipeline ) <= sizeof( UniquePipeline ), "Pipeline is greater than UniquePipeline!" );\r
+ std::vector<UniquePipeline, Allocator> pipelines;\r
+ pipelines.reserve( createInfos.size() );\r
+ Pipeline* buffer = reinterpret_cast<Pipeline*>( reinterpret_cast<char*>( pipelines.data() ) + createInfos.size() * ( sizeof( UniquePipeline ) - sizeof( Pipeline ) ) );\r
+ Result result = static_cast<Result>(d.vkCreateGraphicsPipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), createInfos.size() , reinterpret_cast<const VkGraphicsPipelineCreateInfo*>( createInfos.data() ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( buffer ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ for ( size_t i=0 ; i<createInfos.size() ; i++ )\r
+ {\r
+ pipelines.push_back( UniquePipeline( buffer[i], deleter ) );\r
+ }\r
+\r
+ return createResultValue( result, pipelines, VULKAN_HPP_NAMESPACE_STRING "::Device::createGraphicsPipelinesUnique" );\r
+ }\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE ResultValueType<UniquePipeline>::type Device::createGraphicsPipelineUnique( PipelineCache pipelineCache, const GraphicsPipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Pipeline pipeline;\r
+ Result result = static_cast<Result>( d.vkCreateGraphicsPipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), 1 , reinterpret_cast<const VkGraphicsPipelineCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( &pipeline ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, pipeline, VULKAN_HPP_NAMESPACE_STRING"::Device::createGraphicsPipelineUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createComputePipelines( PipelineCache pipelineCache, uint32_t createInfoCount, const ComputePipelineCreateInfo* pCreateInfos, const AllocationCallbacks* pAllocator, Pipeline* pPipelines, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateComputePipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), createInfoCount, reinterpret_cast<const VkComputePipelineCreateInfo*>( pCreateInfos ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkPipeline*>( pPipelines ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<Pipeline,Allocator>>::type Device::createComputePipelines( PipelineCache pipelineCache, ArrayProxy<const ComputePipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ std::vector<Pipeline,Allocator> pipelines( createInfos.size() );\r
+ Result result = static_cast<Result>( d.vkCreateComputePipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), createInfos.size() , reinterpret_cast<const VkComputePipelineCreateInfo*>( createInfos.data() ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( pipelines.data() ) ) );\r
+ return createResultValue( result, pipelines, VULKAN_HPP_NAMESPACE_STRING"::Device::createComputePipelines" );\r
+ }\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE ResultValueType<Pipeline>::type Device::createComputePipeline( PipelineCache pipelineCache, const ComputePipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Pipeline pipeline;\r
+ Result result = static_cast<Result>( d.vkCreateComputePipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), 1 , reinterpret_cast<const VkComputePipelineCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( &pipeline ) ) );\r
+ return createResultValue( result, pipeline, VULKAN_HPP_NAMESPACE_STRING"::Device::createComputePipeline" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<UniquePipeline,Allocator>>::type Device::createComputePipelinesUnique( PipelineCache pipelineCache, ArrayProxy<const ComputePipelineCreateInfo> createInfos, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ static_assert( sizeof( Pipeline ) <= sizeof( UniquePipeline ), "Pipeline is greater than UniquePipeline!" );\r
+ std::vector<UniquePipeline, Allocator> pipelines;\r
+ pipelines.reserve( createInfos.size() );\r
+ Pipeline* buffer = reinterpret_cast<Pipeline*>( reinterpret_cast<char*>( pipelines.data() ) + createInfos.size() * ( sizeof( UniquePipeline ) - sizeof( Pipeline ) ) );\r
+ Result result = static_cast<Result>(d.vkCreateComputePipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), createInfos.size() , reinterpret_cast<const VkComputePipelineCreateInfo*>( createInfos.data() ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( buffer ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ for ( size_t i=0 ; i<createInfos.size() ; i++ )\r
+ {\r
+ pipelines.push_back( UniquePipeline( buffer[i], deleter ) );\r
+ }\r
+\r
+ return createResultValue( result, pipelines, VULKAN_HPP_NAMESPACE_STRING "::Device::createComputePipelinesUnique" );\r
+ }\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE ResultValueType<UniquePipeline>::type Device::createComputePipelineUnique( PipelineCache pipelineCache, const ComputePipelineCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Pipeline pipeline;\r
+ Result result = static_cast<Result>( d.vkCreateComputePipelines( m_device, static_cast<VkPipelineCache>( pipelineCache ), 1 , reinterpret_cast<const VkComputePipelineCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipeline*>( &pipeline ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, pipeline, VULKAN_HPP_NAMESPACE_STRING"::Device::createComputePipelineUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyPipeline( Pipeline pipeline, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyPipeline( m_device, static_cast<VkPipeline>( pipeline ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyPipeline( Pipeline pipeline, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyPipeline( m_device, static_cast<VkPipeline>( pipeline ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Pipeline pipeline, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyPipeline( m_device, static_cast<VkPipeline>( pipeline ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Pipeline pipeline, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyPipeline( m_device, static_cast<VkPipeline>( pipeline ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createPipelineLayout( const PipelineLayoutCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, PipelineLayout* pPipelineLayout, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreatePipelineLayout( m_device, reinterpret_cast<const VkPipelineLayoutCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkPipelineLayout*>( pPipelineLayout ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<PipelineLayout>::type Device::createPipelineLayout( const PipelineLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ PipelineLayout pipelineLayout;\r
+ Result result = static_cast<Result>( d.vkCreatePipelineLayout( m_device, reinterpret_cast<const VkPipelineLayoutCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipelineLayout*>( &pipelineLayout ) ) );\r
+ return createResultValue( result, pipelineLayout, VULKAN_HPP_NAMESPACE_STRING"::Device::createPipelineLayout" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniquePipelineLayout>::type Device::createPipelineLayoutUnique( const PipelineLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ PipelineLayout pipelineLayout;\r
+ Result result = static_cast<Result>( d.vkCreatePipelineLayout( m_device, reinterpret_cast<const VkPipelineLayoutCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkPipelineLayout*>( &pipelineLayout ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, pipelineLayout, VULKAN_HPP_NAMESPACE_STRING"::Device::createPipelineLayoutUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyPipelineLayout( PipelineLayout pipelineLayout, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyPipelineLayout( m_device, static_cast<VkPipelineLayout>( pipelineLayout ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyPipelineLayout( PipelineLayout pipelineLayout, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyPipelineLayout( m_device, static_cast<VkPipelineLayout>( pipelineLayout ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( PipelineLayout pipelineLayout, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyPipelineLayout( m_device, static_cast<VkPipelineLayout>( pipelineLayout ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( PipelineLayout pipelineLayout, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyPipelineLayout( m_device, static_cast<VkPipelineLayout>( pipelineLayout ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createSampler( const SamplerCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Sampler* pSampler, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateSampler( m_device, reinterpret_cast<const VkSamplerCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSampler*>( pSampler ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Sampler>::type Device::createSampler( const SamplerCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Sampler sampler;\r
+ Result result = static_cast<Result>( d.vkCreateSampler( m_device, reinterpret_cast<const VkSamplerCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSampler*>( &sampler ) ) );\r
+ return createResultValue( result, sampler, VULKAN_HPP_NAMESPACE_STRING"::Device::createSampler" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSampler>::type Device::createSamplerUnique( const SamplerCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Sampler sampler;\r
+ Result result = static_cast<Result>( d.vkCreateSampler( m_device, reinterpret_cast<const VkSamplerCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSampler*>( &sampler ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, sampler, VULKAN_HPP_NAMESPACE_STRING"::Device::createSamplerUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySampler( Sampler sampler, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySampler( m_device, static_cast<VkSampler>( sampler ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySampler( Sampler sampler, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySampler( m_device, static_cast<VkSampler>( sampler ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Sampler sampler, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySampler( m_device, static_cast<VkSampler>( sampler ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Sampler sampler, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySampler( m_device, static_cast<VkSampler>( sampler ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createDescriptorSetLayout( const DescriptorSetLayoutCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorSetLayout* pSetLayout, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDescriptorSetLayout( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDescriptorSetLayout*>( pSetLayout ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DescriptorSetLayout>::type Device::createDescriptorSetLayout( const DescriptorSetLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorSetLayout setLayout;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorSetLayout( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorSetLayout*>( &setLayout ) ) );\r
+ return createResultValue( result, setLayout, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorSetLayout" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDescriptorSetLayout>::type Device::createDescriptorSetLayoutUnique( const DescriptorSetLayoutCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorSetLayout setLayout;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorSetLayout( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorSetLayout*>( &setLayout ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, setLayout, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorSetLayoutUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorSetLayout( DescriptorSetLayout descriptorSetLayout, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorSetLayout( m_device, static_cast<VkDescriptorSetLayout>( descriptorSetLayout ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorSetLayout( DescriptorSetLayout descriptorSetLayout, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorSetLayout( m_device, static_cast<VkDescriptorSetLayout>( descriptorSetLayout ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( DescriptorSetLayout descriptorSetLayout, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorSetLayout( m_device, static_cast<VkDescriptorSetLayout>( descriptorSetLayout ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( DescriptorSetLayout descriptorSetLayout, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorSetLayout( m_device, static_cast<VkDescriptorSetLayout>( descriptorSetLayout ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createDescriptorPool( const DescriptorPoolCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorPool* pDescriptorPool, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDescriptorPool( m_device, reinterpret_cast<const VkDescriptorPoolCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDescriptorPool*>( pDescriptorPool ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DescriptorPool>::type Device::createDescriptorPool( const DescriptorPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorPool descriptorPool;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorPool( m_device, reinterpret_cast<const VkDescriptorPoolCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorPool*>( &descriptorPool ) ) );\r
+ return createResultValue( result, descriptorPool, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorPool" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDescriptorPool>::type Device::createDescriptorPoolUnique( const DescriptorPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorPool descriptorPool;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorPool( m_device, reinterpret_cast<const VkDescriptorPoolCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorPool*>( &descriptorPool ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, descriptorPool, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorPoolUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorPool( DescriptorPool descriptorPool, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorPool( m_device, static_cast<VkDescriptorPool>( descriptorPool ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorPool( DescriptorPool descriptorPool, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorPool( m_device, static_cast<VkDescriptorPool>( descriptorPool ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( DescriptorPool descriptorPool, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorPool( m_device, static_cast<VkDescriptorPool>( descriptorPool ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( DescriptorPool descriptorPool, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorPool( m_device, static_cast<VkDescriptorPool>( descriptorPool ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::resetDescriptorPool( DescriptorPool descriptorPool, DescriptorPoolResetFlags flags, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkResetDescriptorPool( m_device, static_cast<VkDescriptorPool>( descriptorPool ), static_cast<VkDescriptorPoolResetFlags>( flags ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::resetDescriptorPool( DescriptorPool descriptorPool, DescriptorPoolResetFlags flags, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkResetDescriptorPool( m_device, static_cast<VkDescriptorPool>( descriptorPool ), static_cast<VkDescriptorPoolResetFlags>( flags ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::resetDescriptorPool" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::allocateDescriptorSets( const DescriptorSetAllocateInfo* pAllocateInfo, DescriptorSet* pDescriptorSets, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkAllocateDescriptorSets( m_device, reinterpret_cast<const VkDescriptorSetAllocateInfo*>( pAllocateInfo ), reinterpret_cast<VkDescriptorSet*>( pDescriptorSets ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<DescriptorSet,Allocator>>::type Device::allocateDescriptorSets( const DescriptorSetAllocateInfo & allocateInfo, Dispatch const &d ) const\r
+ {\r
+ std::vector<DescriptorSet,Allocator> descriptorSets( allocateInfo.descriptorSetCount );\r
+ Result result = static_cast<Result>( d.vkAllocateDescriptorSets( m_device, reinterpret_cast<const VkDescriptorSetAllocateInfo*>( &allocateInfo ), reinterpret_cast<VkDescriptorSet*>( descriptorSets.data() ) ) );\r
+ return createResultValue( result, descriptorSets, VULKAN_HPP_NAMESPACE_STRING"::Device::allocateDescriptorSets" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<UniqueDescriptorSet,Allocator>>::type Device::allocateDescriptorSetsUnique( const DescriptorSetAllocateInfo & allocateInfo, Dispatch const &d ) const\r
+ {\r
+ static_assert( sizeof( DescriptorSet ) <= sizeof( UniqueDescriptorSet ), "DescriptorSet is greater than UniqueDescriptorSet!" );\r
+ std::vector<UniqueDescriptorSet, Allocator> descriptorSets;\r
+ descriptorSets.reserve( allocateInfo.descriptorSetCount );\r
+ DescriptorSet* buffer = reinterpret_cast<DescriptorSet*>( reinterpret_cast<char*>( descriptorSets.data() ) + allocateInfo.descriptorSetCount * ( sizeof( UniqueDescriptorSet ) - sizeof( DescriptorSet ) ) );\r
+ Result result = static_cast<Result>(d.vkAllocateDescriptorSets( m_device, reinterpret_cast<const VkDescriptorSetAllocateInfo*>( &allocateInfo ), reinterpret_cast<VkDescriptorSet*>( buffer ) ) );\r
+\r
+ PoolFree<Device,DescriptorPool> deleter( *this, allocateInfo.descriptorPool );\r
+ for ( size_t i=0 ; i<allocateInfo.descriptorSetCount ; i++ )\r
+ {\r
+ descriptorSets.push_back( UniqueDescriptorSet( buffer[i], deleter ) );\r
+ }\r
+\r
+ return createResultValue( result, descriptorSets, VULKAN_HPP_NAMESPACE_STRING "::Device::allocateDescriptorSetsUnique" );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::freeDescriptorSets( DescriptorPool descriptorPool, uint32_t descriptorSetCount, const DescriptorSet* pDescriptorSets, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkFreeDescriptorSets( m_device, static_cast<VkDescriptorPool>( descriptorPool ), descriptorSetCount, reinterpret_cast<const VkDescriptorSet*>( pDescriptorSets ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::freeDescriptorSets( DescriptorPool descriptorPool, ArrayProxy<const DescriptorSet> descriptorSets, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkFreeDescriptorSets( m_device, static_cast<VkDescriptorPool>( descriptorPool ), descriptorSets.size() , reinterpret_cast<const VkDescriptorSet*>( descriptorSets.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::freeDescriptorSets" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::free( DescriptorPool descriptorPool, uint32_t descriptorSetCount, const DescriptorSet* pDescriptorSets, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkFreeDescriptorSets( m_device, static_cast<VkDescriptorPool>( descriptorPool ), descriptorSetCount, reinterpret_cast<const VkDescriptorSet*>( pDescriptorSets ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::free( DescriptorPool descriptorPool, ArrayProxy<const DescriptorSet> descriptorSets, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkFreeDescriptorSets( m_device, static_cast<VkDescriptorPool>( descriptorPool ), descriptorSets.size() , reinterpret_cast<const VkDescriptorSet*>( descriptorSets.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::free" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::updateDescriptorSets( uint32_t descriptorWriteCount, const WriteDescriptorSet* pDescriptorWrites, uint32_t descriptorCopyCount, const CopyDescriptorSet* pDescriptorCopies, Dispatch const &d) const\r
+ {\r
+ d.vkUpdateDescriptorSets( m_device, descriptorWriteCount, reinterpret_cast<const VkWriteDescriptorSet*>( pDescriptorWrites ), descriptorCopyCount, reinterpret_cast<const VkCopyDescriptorSet*>( pDescriptorCopies ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::updateDescriptorSets( ArrayProxy<const WriteDescriptorSet> descriptorWrites, ArrayProxy<const CopyDescriptorSet> descriptorCopies, Dispatch const &d ) const\r
+ {\r
+ d.vkUpdateDescriptorSets( m_device, descriptorWrites.size() , reinterpret_cast<const VkWriteDescriptorSet*>( descriptorWrites.data() ), descriptorCopies.size() , reinterpret_cast<const VkCopyDescriptorSet*>( descriptorCopies.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createFramebuffer( const FramebufferCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Framebuffer* pFramebuffer, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateFramebuffer( m_device, reinterpret_cast<const VkFramebufferCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkFramebuffer*>( pFramebuffer ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Framebuffer>::type Device::createFramebuffer( const FramebufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Framebuffer framebuffer;\r
+ Result result = static_cast<Result>( d.vkCreateFramebuffer( m_device, reinterpret_cast<const VkFramebufferCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkFramebuffer*>( &framebuffer ) ) );\r
+ return createResultValue( result, framebuffer, VULKAN_HPP_NAMESPACE_STRING"::Device::createFramebuffer" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueFramebuffer>::type Device::createFramebufferUnique( const FramebufferCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Framebuffer framebuffer;\r
+ Result result = static_cast<Result>( d.vkCreateFramebuffer( m_device, reinterpret_cast<const VkFramebufferCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkFramebuffer*>( &framebuffer ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, framebuffer, VULKAN_HPP_NAMESPACE_STRING"::Device::createFramebufferUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyFramebuffer( Framebuffer framebuffer, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyFramebuffer( m_device, static_cast<VkFramebuffer>( framebuffer ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyFramebuffer( Framebuffer framebuffer, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyFramebuffer( m_device, static_cast<VkFramebuffer>( framebuffer ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Framebuffer framebuffer, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyFramebuffer( m_device, static_cast<VkFramebuffer>( framebuffer ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( Framebuffer framebuffer, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyFramebuffer( m_device, static_cast<VkFramebuffer>( framebuffer ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createRenderPass( const RenderPassCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, RenderPass* pRenderPass, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateRenderPass( m_device, reinterpret_cast<const VkRenderPassCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkRenderPass*>( pRenderPass ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<RenderPass>::type Device::createRenderPass( const RenderPassCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ RenderPass renderPass;\r
+ Result result = static_cast<Result>( d.vkCreateRenderPass( m_device, reinterpret_cast<const VkRenderPassCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkRenderPass*>( &renderPass ) ) );\r
+ return createResultValue( result, renderPass, VULKAN_HPP_NAMESPACE_STRING"::Device::createRenderPass" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueRenderPass>::type Device::createRenderPassUnique( const RenderPassCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ RenderPass renderPass;\r
+ Result result = static_cast<Result>( d.vkCreateRenderPass( m_device, reinterpret_cast<const VkRenderPassCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkRenderPass*>( &renderPass ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, renderPass, VULKAN_HPP_NAMESPACE_STRING"::Device::createRenderPassUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyRenderPass( RenderPass renderPass, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyRenderPass( m_device, static_cast<VkRenderPass>( renderPass ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyRenderPass( RenderPass renderPass, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyRenderPass( m_device, static_cast<VkRenderPass>( renderPass ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( RenderPass renderPass, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyRenderPass( m_device, static_cast<VkRenderPass>( renderPass ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( RenderPass renderPass, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyRenderPass( m_device, static_cast<VkRenderPass>( renderPass ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getRenderAreaGranularity( RenderPass renderPass, Extent2D* pGranularity, Dispatch const &d) const\r
+ {\r
+ d.vkGetRenderAreaGranularity( m_device, static_cast<VkRenderPass>( renderPass ), reinterpret_cast<VkExtent2D*>( pGranularity ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Extent2D Device::getRenderAreaGranularity( RenderPass renderPass, Dispatch const &d ) const\r
+ {\r
+ Extent2D granularity;\r
+ d.vkGetRenderAreaGranularity( m_device, static_cast<VkRenderPass>( renderPass ), reinterpret_cast<VkExtent2D*>( &granularity ) );\r
+ return granularity;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createCommandPool( const CommandPoolCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, CommandPool* pCommandPool, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateCommandPool( m_device, reinterpret_cast<const VkCommandPoolCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkCommandPool*>( pCommandPool ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<CommandPool>::type Device::createCommandPool( const CommandPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ CommandPool commandPool;\r
+ Result result = static_cast<Result>( d.vkCreateCommandPool( m_device, reinterpret_cast<const VkCommandPoolCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkCommandPool*>( &commandPool ) ) );\r
+ return createResultValue( result, commandPool, VULKAN_HPP_NAMESPACE_STRING"::Device::createCommandPool" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueCommandPool>::type Device::createCommandPoolUnique( const CommandPoolCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ CommandPool commandPool;\r
+ Result result = static_cast<Result>( d.vkCreateCommandPool( m_device, reinterpret_cast<const VkCommandPoolCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkCommandPool*>( &commandPool ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, commandPool, VULKAN_HPP_NAMESPACE_STRING"::Device::createCommandPoolUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyCommandPool( CommandPool commandPool, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyCommandPool( CommandPool commandPool, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( CommandPool commandPool, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( CommandPool commandPool, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::resetCommandPool( CommandPool commandPool, CommandPoolResetFlags flags, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkResetCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), static_cast<VkCommandPoolResetFlags>( flags ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::resetCommandPool( CommandPool commandPool, CommandPoolResetFlags flags, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkResetCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), static_cast<VkCommandPoolResetFlags>( flags ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::resetCommandPool" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::allocateCommandBuffers( const CommandBufferAllocateInfo* pAllocateInfo, CommandBuffer* pCommandBuffers, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkAllocateCommandBuffers( m_device, reinterpret_cast<const VkCommandBufferAllocateInfo*>( pAllocateInfo ), reinterpret_cast<VkCommandBuffer*>( pCommandBuffers ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<CommandBuffer,Allocator>>::type Device::allocateCommandBuffers( const CommandBufferAllocateInfo & allocateInfo, Dispatch const &d ) const\r
+ {\r
+ std::vector<CommandBuffer,Allocator> commandBuffers( allocateInfo.commandBufferCount );\r
+ Result result = static_cast<Result>( d.vkAllocateCommandBuffers( m_device, reinterpret_cast<const VkCommandBufferAllocateInfo*>( &allocateInfo ), reinterpret_cast<VkCommandBuffer*>( commandBuffers.data() ) ) );\r
+ return createResultValue( result, commandBuffers, VULKAN_HPP_NAMESPACE_STRING"::Device::allocateCommandBuffers" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<UniqueCommandBuffer,Allocator>>::type Device::allocateCommandBuffersUnique( const CommandBufferAllocateInfo & allocateInfo, Dispatch const &d ) const\r
+ {\r
+ static_assert( sizeof( CommandBuffer ) <= sizeof( UniqueCommandBuffer ), "CommandBuffer is greater than UniqueCommandBuffer!" );\r
+ std::vector<UniqueCommandBuffer, Allocator> commandBuffers;\r
+ commandBuffers.reserve( allocateInfo.commandBufferCount );\r
+ CommandBuffer* buffer = reinterpret_cast<CommandBuffer*>( reinterpret_cast<char*>( commandBuffers.data() ) + allocateInfo.commandBufferCount * ( sizeof( UniqueCommandBuffer ) - sizeof( CommandBuffer ) ) );\r
+ Result result = static_cast<Result>(d.vkAllocateCommandBuffers( m_device, reinterpret_cast<const VkCommandBufferAllocateInfo*>( &allocateInfo ), reinterpret_cast<VkCommandBuffer*>( buffer ) ) );\r
+\r
+ PoolFree<Device,CommandPool> deleter( *this, allocateInfo.commandPool );\r
+ for ( size_t i=0 ; i<allocateInfo.commandBufferCount ; i++ )\r
+ {\r
+ commandBuffers.push_back( UniqueCommandBuffer( buffer[i], deleter ) );\r
+ }\r
+\r
+ return createResultValue( result, commandBuffers, VULKAN_HPP_NAMESPACE_STRING "::Device::allocateCommandBuffersUnique" );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::freeCommandBuffers( CommandPool commandPool, uint32_t commandBufferCount, const CommandBuffer* pCommandBuffers, Dispatch const &d) const\r
+ {\r
+ d.vkFreeCommandBuffers( m_device, static_cast<VkCommandPool>( commandPool ), commandBufferCount, reinterpret_cast<const VkCommandBuffer*>( pCommandBuffers ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::freeCommandBuffers( CommandPool commandPool, ArrayProxy<const CommandBuffer> commandBuffers, Dispatch const &d ) const\r
+ {\r
+ d.vkFreeCommandBuffers( m_device, static_cast<VkCommandPool>( commandPool ), commandBuffers.size() , reinterpret_cast<const VkCommandBuffer*>( commandBuffers.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::free( CommandPool commandPool, uint32_t commandBufferCount, const CommandBuffer* pCommandBuffers, Dispatch const &d) const\r
+ {\r
+ d.vkFreeCommandBuffers( m_device, static_cast<VkCommandPool>( commandPool ), commandBufferCount, reinterpret_cast<const VkCommandBuffer*>( pCommandBuffers ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::free( CommandPool commandPool, ArrayProxy<const CommandBuffer> commandBuffers, Dispatch const &d ) const\r
+ {\r
+ d.vkFreeCommandBuffers( m_device, static_cast<VkCommandPool>( commandPool ), commandBuffers.size() , reinterpret_cast<const VkCommandBuffer*>( commandBuffers.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createSharedSwapchainsKHR( uint32_t swapchainCount, const SwapchainCreateInfoKHR* pCreateInfos, const AllocationCallbacks* pAllocator, SwapchainKHR* pSwapchains, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateSharedSwapchainsKHR( m_device, swapchainCount, reinterpret_cast<const VkSwapchainCreateInfoKHR*>( pCreateInfos ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSwapchainKHR*>( pSwapchains ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<SwapchainKHR,Allocator>>::type Device::createSharedSwapchainsKHR( ArrayProxy<const SwapchainCreateInfoKHR> createInfos, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ std::vector<SwapchainKHR,Allocator> swapchains( createInfos.size() );\r
+ Result result = static_cast<Result>( d.vkCreateSharedSwapchainsKHR( m_device, createInfos.size() , reinterpret_cast<const VkSwapchainCreateInfoKHR*>( createInfos.data() ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSwapchainKHR*>( swapchains.data() ) ) );\r
+ return createResultValue( result, swapchains, VULKAN_HPP_NAMESPACE_STRING"::Device::createSharedSwapchainsKHR" );\r
+ }\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE ResultValueType<SwapchainKHR>::type Device::createSharedSwapchainKHR( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SwapchainKHR swapchain;\r
+ Result result = static_cast<Result>( d.vkCreateSharedSwapchainsKHR( m_device, 1 , reinterpret_cast<const VkSwapchainCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSwapchainKHR*>( &swapchain ) ) );\r
+ return createResultValue( result, swapchain, VULKAN_HPP_NAMESPACE_STRING"::Device::createSharedSwapchainKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<UniqueSwapchainKHR,Allocator>>::type Device::createSharedSwapchainsKHRUnique( ArrayProxy<const SwapchainCreateInfoKHR> createInfos, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ static_assert( sizeof( SwapchainKHR ) <= sizeof( UniqueSwapchainKHR ), "SwapchainKHR is greater than UniqueSwapchainKHR!" );\r
+ std::vector<UniqueSwapchainKHR, Allocator> swapchainKHRs;\r
+ swapchainKHRs.reserve( createInfos.size() );\r
+ SwapchainKHR* buffer = reinterpret_cast<SwapchainKHR*>( reinterpret_cast<char*>( swapchainKHRs.data() ) + createInfos.size() * ( sizeof( UniqueSwapchainKHR ) - sizeof( SwapchainKHR ) ) );\r
+ Result result = static_cast<Result>(d.vkCreateSharedSwapchainsKHR( m_device, createInfos.size() , reinterpret_cast<const VkSwapchainCreateInfoKHR*>( createInfos.data() ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSwapchainKHR*>( buffer ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ for ( size_t i=0 ; i<createInfos.size() ; i++ )\r
+ {\r
+ swapchainKHRs.push_back( UniqueSwapchainKHR( buffer[i], deleter ) );\r
+ }\r
+\r
+ return createResultValue( result, swapchainKHRs, VULKAN_HPP_NAMESPACE_STRING "::Device::createSharedSwapchainsKHRUnique" );\r
+ }\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSwapchainKHR>::type Device::createSharedSwapchainKHRUnique( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SwapchainKHR swapchain;\r
+ Result result = static_cast<Result>( d.vkCreateSharedSwapchainsKHR( m_device, 1 , reinterpret_cast<const VkSwapchainCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSwapchainKHR*>( &swapchain ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, swapchain, VULKAN_HPP_NAMESPACE_STRING"::Device::createSharedSwapchainKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createSwapchainKHR( const SwapchainCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SwapchainKHR* pSwapchain, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateSwapchainKHR( m_device, reinterpret_cast<const VkSwapchainCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSwapchainKHR*>( pSwapchain ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SwapchainKHR>::type Device::createSwapchainKHR( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SwapchainKHR swapchain;\r
+ Result result = static_cast<Result>( d.vkCreateSwapchainKHR( m_device, reinterpret_cast<const VkSwapchainCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSwapchainKHR*>( &swapchain ) ) );\r
+ return createResultValue( result, swapchain, VULKAN_HPP_NAMESPACE_STRING"::Device::createSwapchainKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSwapchainKHR>::type Device::createSwapchainKHRUnique( const SwapchainCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SwapchainKHR swapchain;\r
+ Result result = static_cast<Result>( d.vkCreateSwapchainKHR( m_device, reinterpret_cast<const VkSwapchainCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSwapchainKHR*>( &swapchain ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, swapchain, VULKAN_HPP_NAMESPACE_STRING"::Device::createSwapchainKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySwapchainKHR( SwapchainKHR swapchain, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySwapchainKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySwapchainKHR( SwapchainKHR swapchain, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySwapchainKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( SwapchainKHR swapchain, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySwapchainKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( SwapchainKHR swapchain, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySwapchainKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getSwapchainImagesKHR( SwapchainKHR swapchain, uint32_t* pSwapchainImageCount, Image* pSwapchainImages, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetSwapchainImagesKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), pSwapchainImageCount, reinterpret_cast<VkImage*>( pSwapchainImages ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<Image,Allocator>>::type Device::getSwapchainImagesKHR( SwapchainKHR swapchain, Dispatch const &d ) const\r
+ {\r
+ std::vector<Image,Allocator> swapchainImages;\r
+ uint32_t swapchainImageCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetSwapchainImagesKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), &swapchainImageCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && swapchainImageCount )\r
+ {\r
+ swapchainImages.resize( swapchainImageCount );\r
+ result = static_cast<Result>( d.vkGetSwapchainImagesKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), &swapchainImageCount, reinterpret_cast<VkImage*>( swapchainImages.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( swapchainImageCount <= swapchainImages.size() );\r
+ swapchainImages.resize( swapchainImageCount );\r
+ return createResultValue( result, swapchainImages, VULKAN_HPP_NAMESPACE_STRING"::Device::getSwapchainImagesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::acquireNextImageKHR( SwapchainKHR swapchain, uint64_t timeout, Semaphore semaphore, Fence fence, uint32_t* pImageIndex, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkAcquireNextImageKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), timeout, static_cast<VkSemaphore>( semaphore ), static_cast<VkFence>( fence ), pImageIndex ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValue<uint32_t> Device::acquireNextImageKHR( SwapchainKHR swapchain, uint64_t timeout, Semaphore semaphore, Fence fence, Dispatch const &d ) const\r
+ {\r
+ uint32_t imageIndex;\r
+ Result result = static_cast<Result>( d.vkAcquireNextImageKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ), timeout, static_cast<VkSemaphore>( semaphore ), static_cast<VkFence>( fence ), &imageIndex ) );\r
+ return createResultValue( result, imageIndex, VULKAN_HPP_NAMESPACE_STRING"::Device::acquireNextImageKHR", { Result::eSuccess, Result::eTimeout, Result::eNotReady, Result::eSuboptimalKHR } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::debugMarkerSetObjectNameEXT( const DebugMarkerObjectNameInfoEXT* pNameInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkDebugMarkerSetObjectNameEXT( m_device, reinterpret_cast<const VkDebugMarkerObjectNameInfoEXT*>( pNameInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::debugMarkerSetObjectNameEXT( const DebugMarkerObjectNameInfoEXT & nameInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkDebugMarkerSetObjectNameEXT( m_device, reinterpret_cast<const VkDebugMarkerObjectNameInfoEXT*>( &nameInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::debugMarkerSetObjectNameEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::debugMarkerSetObjectTagEXT( const DebugMarkerObjectTagInfoEXT* pTagInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkDebugMarkerSetObjectTagEXT( m_device, reinterpret_cast<const VkDebugMarkerObjectTagInfoEXT*>( pTagInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::debugMarkerSetObjectTagEXT( const DebugMarkerObjectTagInfoEXT & tagInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkDebugMarkerSetObjectTagEXT( m_device, reinterpret_cast<const VkDebugMarkerObjectTagInfoEXT*>( &tagInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::debugMarkerSetObjectTagEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryWin32HandleNV( DeviceMemory memory, ExternalMemoryHandleTypeFlagsNV handleType, HANDLE* pHandle, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryWin32HandleNV( m_device, static_cast<VkDeviceMemory>( memory ), static_cast<VkExternalMemoryHandleTypeFlagsNV>( handleType ), pHandle ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<HANDLE>::type Device::getMemoryWin32HandleNV( DeviceMemory memory, ExternalMemoryHandleTypeFlagsNV handleType, Dispatch const &d ) const\r
+ {\r
+ HANDLE handle;\r
+ Result result = static_cast<Result>( d.vkGetMemoryWin32HandleNV( m_device, static_cast<VkDeviceMemory>( memory ), static_cast<VkExternalMemoryHandleTypeFlagsNV>( handleType ), &handle ) );\r
+ return createResultValue( result, handle, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryWin32HandleNV" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createIndirectCommandsLayoutNVX( const IndirectCommandsLayoutCreateInfoNVX* pCreateInfo, const AllocationCallbacks* pAllocator, IndirectCommandsLayoutNVX* pIndirectCommandsLayout, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateIndirectCommandsLayoutNVX( m_device, reinterpret_cast<const VkIndirectCommandsLayoutCreateInfoNVX*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkIndirectCommandsLayoutNVX*>( pIndirectCommandsLayout ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<IndirectCommandsLayoutNVX>::type Device::createIndirectCommandsLayoutNVX( const IndirectCommandsLayoutCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ IndirectCommandsLayoutNVX indirectCommandsLayout;\r
+ Result result = static_cast<Result>( d.vkCreateIndirectCommandsLayoutNVX( m_device, reinterpret_cast<const VkIndirectCommandsLayoutCreateInfoNVX*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkIndirectCommandsLayoutNVX*>( &indirectCommandsLayout ) ) );\r
+ return createResultValue( result, indirectCommandsLayout, VULKAN_HPP_NAMESPACE_STRING"::Device::createIndirectCommandsLayoutNVX" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueIndirectCommandsLayoutNVX>::type Device::createIndirectCommandsLayoutNVXUnique( const IndirectCommandsLayoutCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ IndirectCommandsLayoutNVX indirectCommandsLayout;\r
+ Result result = static_cast<Result>( d.vkCreateIndirectCommandsLayoutNVX( m_device, reinterpret_cast<const VkIndirectCommandsLayoutCreateInfoNVX*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkIndirectCommandsLayoutNVX*>( &indirectCommandsLayout ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, indirectCommandsLayout, VULKAN_HPP_NAMESPACE_STRING"::Device::createIndirectCommandsLayoutNVXUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyIndirectCommandsLayoutNVX( IndirectCommandsLayoutNVX indirectCommandsLayout, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyIndirectCommandsLayoutNVX( m_device, static_cast<VkIndirectCommandsLayoutNVX>( indirectCommandsLayout ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyIndirectCommandsLayoutNVX( IndirectCommandsLayoutNVX indirectCommandsLayout, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyIndirectCommandsLayoutNVX( m_device, static_cast<VkIndirectCommandsLayoutNVX>( indirectCommandsLayout ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( IndirectCommandsLayoutNVX indirectCommandsLayout, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyIndirectCommandsLayoutNVX( m_device, static_cast<VkIndirectCommandsLayoutNVX>( indirectCommandsLayout ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( IndirectCommandsLayoutNVX indirectCommandsLayout, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyIndirectCommandsLayoutNVX( m_device, static_cast<VkIndirectCommandsLayoutNVX>( indirectCommandsLayout ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createObjectTableNVX( const ObjectTableCreateInfoNVX* pCreateInfo, const AllocationCallbacks* pAllocator, ObjectTableNVX* pObjectTable, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateObjectTableNVX( m_device, reinterpret_cast<const VkObjectTableCreateInfoNVX*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkObjectTableNVX*>( pObjectTable ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ObjectTableNVX>::type Device::createObjectTableNVX( const ObjectTableCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ObjectTableNVX objectTable;\r
+ Result result = static_cast<Result>( d.vkCreateObjectTableNVX( m_device, reinterpret_cast<const VkObjectTableCreateInfoNVX*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkObjectTableNVX*>( &objectTable ) ) );\r
+ return createResultValue( result, objectTable, VULKAN_HPP_NAMESPACE_STRING"::Device::createObjectTableNVX" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueObjectTableNVX>::type Device::createObjectTableNVXUnique( const ObjectTableCreateInfoNVX & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ObjectTableNVX objectTable;\r
+ Result result = static_cast<Result>( d.vkCreateObjectTableNVX( m_device, reinterpret_cast<const VkObjectTableCreateInfoNVX*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkObjectTableNVX*>( &objectTable ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, objectTable, VULKAN_HPP_NAMESPACE_STRING"::Device::createObjectTableNVXUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyObjectTableNVX( ObjectTableNVX objectTable, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyObjectTableNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyObjectTableNVX( ObjectTableNVX objectTable, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyObjectTableNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ObjectTableNVX objectTable, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyObjectTableNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ObjectTableNVX objectTable, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyObjectTableNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::registerObjectsNVX( ObjectTableNVX objectTable, uint32_t objectCount, const ObjectTableEntryNVX* const* ppObjectTableEntries, const uint32_t* pObjectIndices, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkRegisterObjectsNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), objectCount, reinterpret_cast<const VkObjectTableEntryNVX* const*>( ppObjectTableEntries ), pObjectIndices ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::registerObjectsNVX( ObjectTableNVX objectTable, ArrayProxy<const ObjectTableEntryNVX* const> pObjectTableEntries, ArrayProxy<const uint32_t> objectIndices, Dispatch const &d ) const\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( pObjectTableEntries.size() == objectIndices.size() );\r
+#else\r
+ if ( pObjectTableEntries.size() != objectIndices.size() )\r
+ {\r
+ throw LogicError( VULKAN_HPP_NAMESPACE_STRING "::Device::registerObjectsNVX: pObjectTableEntries.size() != objectIndices.size()" );\r
+ }\r
+#endif // VULKAN_HPP_NO_EXCEPTIONS\r
+ Result result = static_cast<Result>( d.vkRegisterObjectsNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), pObjectTableEntries.size() , reinterpret_cast<const VkObjectTableEntryNVX* const*>( pObjectTableEntries.data() ), objectIndices.data() ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::registerObjectsNVX" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::unregisterObjectsNVX( ObjectTableNVX objectTable, uint32_t objectCount, const ObjectEntryTypeNVX* pObjectEntryTypes, const uint32_t* pObjectIndices, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkUnregisterObjectsNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), objectCount, reinterpret_cast<const VkObjectEntryTypeNVX*>( pObjectEntryTypes ), pObjectIndices ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::unregisterObjectsNVX( ObjectTableNVX objectTable, ArrayProxy<const ObjectEntryTypeNVX> objectEntryTypes, ArrayProxy<const uint32_t> objectIndices, Dispatch const &d ) const\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( objectEntryTypes.size() == objectIndices.size() );\r
+#else\r
+ if ( objectEntryTypes.size() != objectIndices.size() )\r
+ {\r
+ throw LogicError( VULKAN_HPP_NAMESPACE_STRING "::Device::unregisterObjectsNVX: objectEntryTypes.size() != objectIndices.size()" );\r
+ }\r
+#endif // VULKAN_HPP_NO_EXCEPTIONS\r
+ Result result = static_cast<Result>( d.vkUnregisterObjectsNVX( m_device, static_cast<VkObjectTableNVX>( objectTable ), objectEntryTypes.size() , reinterpret_cast<const VkObjectEntryTypeNVX*>( objectEntryTypes.data() ), objectIndices.data() ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::unregisterObjectsNVX" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::trimCommandPool( CommandPool commandPool, CommandPoolTrimFlags flags, Dispatch const &d) const\r
+ {\r
+ d.vkTrimCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), static_cast<VkCommandPoolTrimFlags>( flags ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::trimCommandPool( CommandPool commandPool, CommandPoolTrimFlags flags, Dispatch const &d ) const\r
+ {\r
+ d.vkTrimCommandPool( m_device, static_cast<VkCommandPool>( commandPool ), static_cast<VkCommandPoolTrimFlags>( flags ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::trimCommandPoolKHR( CommandPool commandPool, CommandPoolTrimFlags flags, Dispatch const &d) const\r
+ {\r
+ d.vkTrimCommandPoolKHR( m_device, static_cast<VkCommandPool>( commandPool ), static_cast<VkCommandPoolTrimFlags>( flags ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::trimCommandPoolKHR( CommandPool commandPool, CommandPoolTrimFlags flags, Dispatch const &d ) const\r
+ {\r
+ d.vkTrimCommandPoolKHR( m_device, static_cast<VkCommandPool>( commandPool ), static_cast<VkCommandPoolTrimFlags>( flags ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryWin32HandleKHR( const MemoryGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryWin32HandleKHR( m_device, reinterpret_cast<const VkMemoryGetWin32HandleInfoKHR*>( pGetWin32HandleInfo ), pHandle ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<HANDLE>::type Device::getMemoryWin32HandleKHR( const MemoryGetWin32HandleInfoKHR & getWin32HandleInfo, Dispatch const &d ) const\r
+ {\r
+ HANDLE handle;\r
+ Result result = static_cast<Result>( d.vkGetMemoryWin32HandleKHR( m_device, reinterpret_cast<const VkMemoryGetWin32HandleInfoKHR*>( &getWin32HandleInfo ), &handle ) );\r
+ return createResultValue( result, handle, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryWin32HandleKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryWin32HandlePropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, HANDLE handle, MemoryWin32HandlePropertiesKHR* pMemoryWin32HandleProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryWin32HandlePropertiesKHR( m_device, static_cast<VkExternalMemoryHandleTypeFlagBits>( handleType ), handle, reinterpret_cast<VkMemoryWin32HandlePropertiesKHR*>( pMemoryWin32HandleProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<MemoryWin32HandlePropertiesKHR>::type Device::getMemoryWin32HandlePropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, HANDLE handle, Dispatch const &d ) const\r
+ {\r
+ MemoryWin32HandlePropertiesKHR memoryWin32HandleProperties;\r
+ Result result = static_cast<Result>( d.vkGetMemoryWin32HandlePropertiesKHR( m_device, static_cast<VkExternalMemoryHandleTypeFlagBits>( handleType ), handle, reinterpret_cast<VkMemoryWin32HandlePropertiesKHR*>( &memoryWin32HandleProperties ) ) );\r
+ return createResultValue( result, memoryWin32HandleProperties, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryWin32HandlePropertiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryFdKHR( const MemoryGetFdInfoKHR* pGetFdInfo, int* pFd, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryFdKHR( m_device, reinterpret_cast<const VkMemoryGetFdInfoKHR*>( pGetFdInfo ), pFd ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<int>::type Device::getMemoryFdKHR( const MemoryGetFdInfoKHR & getFdInfo, Dispatch const &d ) const\r
+ {\r
+ int fd;\r
+ Result result = static_cast<Result>( d.vkGetMemoryFdKHR( m_device, reinterpret_cast<const VkMemoryGetFdInfoKHR*>( &getFdInfo ), &fd ) );\r
+ return createResultValue( result, fd, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryFdKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryFdPropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, int fd, MemoryFdPropertiesKHR* pMemoryFdProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryFdPropertiesKHR( m_device, static_cast<VkExternalMemoryHandleTypeFlagBits>( handleType ), fd, reinterpret_cast<VkMemoryFdPropertiesKHR*>( pMemoryFdProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<MemoryFdPropertiesKHR>::type Device::getMemoryFdPropertiesKHR( ExternalMemoryHandleTypeFlagBits handleType, int fd, Dispatch const &d ) const\r
+ {\r
+ MemoryFdPropertiesKHR memoryFdProperties;\r
+ Result result = static_cast<Result>( d.vkGetMemoryFdPropertiesKHR( m_device, static_cast<VkExternalMemoryHandleTypeFlagBits>( handleType ), fd, reinterpret_cast<VkMemoryFdPropertiesKHR*>( &memoryFdProperties ) ) );\r
+ return createResultValue( result, memoryFdProperties, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryFdPropertiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getSemaphoreWin32HandleKHR( const SemaphoreGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetSemaphoreWin32HandleKHR( m_device, reinterpret_cast<const VkSemaphoreGetWin32HandleInfoKHR*>( pGetWin32HandleInfo ), pHandle ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<HANDLE>::type Device::getSemaphoreWin32HandleKHR( const SemaphoreGetWin32HandleInfoKHR & getWin32HandleInfo, Dispatch const &d ) const\r
+ {\r
+ HANDLE handle;\r
+ Result result = static_cast<Result>( d.vkGetSemaphoreWin32HandleKHR( m_device, reinterpret_cast<const VkSemaphoreGetWin32HandleInfoKHR*>( &getWin32HandleInfo ), &handle ) );\r
+ return createResultValue( result, handle, VULKAN_HPP_NAMESPACE_STRING"::Device::getSemaphoreWin32HandleKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::importSemaphoreWin32HandleKHR( const ImportSemaphoreWin32HandleInfoKHR* pImportSemaphoreWin32HandleInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkImportSemaphoreWin32HandleKHR( m_device, reinterpret_cast<const VkImportSemaphoreWin32HandleInfoKHR*>( pImportSemaphoreWin32HandleInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::importSemaphoreWin32HandleKHR( const ImportSemaphoreWin32HandleInfoKHR & importSemaphoreWin32HandleInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkImportSemaphoreWin32HandleKHR( m_device, reinterpret_cast<const VkImportSemaphoreWin32HandleInfoKHR*>( &importSemaphoreWin32HandleInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::importSemaphoreWin32HandleKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getSemaphoreFdKHR( const SemaphoreGetFdInfoKHR* pGetFdInfo, int* pFd, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetSemaphoreFdKHR( m_device, reinterpret_cast<const VkSemaphoreGetFdInfoKHR*>( pGetFdInfo ), pFd ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<int>::type Device::getSemaphoreFdKHR( const SemaphoreGetFdInfoKHR & getFdInfo, Dispatch const &d ) const\r
+ {\r
+ int fd;\r
+ Result result = static_cast<Result>( d.vkGetSemaphoreFdKHR( m_device, reinterpret_cast<const VkSemaphoreGetFdInfoKHR*>( &getFdInfo ), &fd ) );\r
+ return createResultValue( result, fd, VULKAN_HPP_NAMESPACE_STRING"::Device::getSemaphoreFdKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::importSemaphoreFdKHR( const ImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkImportSemaphoreFdKHR( m_device, reinterpret_cast<const VkImportSemaphoreFdInfoKHR*>( pImportSemaphoreFdInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::importSemaphoreFdKHR( const ImportSemaphoreFdInfoKHR & importSemaphoreFdInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkImportSemaphoreFdKHR( m_device, reinterpret_cast<const VkImportSemaphoreFdInfoKHR*>( &importSemaphoreFdInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::importSemaphoreFdKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getFenceWin32HandleKHR( const FenceGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetFenceWin32HandleKHR( m_device, reinterpret_cast<const VkFenceGetWin32HandleInfoKHR*>( pGetWin32HandleInfo ), pHandle ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<HANDLE>::type Device::getFenceWin32HandleKHR( const FenceGetWin32HandleInfoKHR & getWin32HandleInfo, Dispatch const &d ) const\r
+ {\r
+ HANDLE handle;\r
+ Result result = static_cast<Result>( d.vkGetFenceWin32HandleKHR( m_device, reinterpret_cast<const VkFenceGetWin32HandleInfoKHR*>( &getWin32HandleInfo ), &handle ) );\r
+ return createResultValue( result, handle, VULKAN_HPP_NAMESPACE_STRING"::Device::getFenceWin32HandleKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::importFenceWin32HandleKHR( const ImportFenceWin32HandleInfoKHR* pImportFenceWin32HandleInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkImportFenceWin32HandleKHR( m_device, reinterpret_cast<const VkImportFenceWin32HandleInfoKHR*>( pImportFenceWin32HandleInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::importFenceWin32HandleKHR( const ImportFenceWin32HandleInfoKHR & importFenceWin32HandleInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkImportFenceWin32HandleKHR( m_device, reinterpret_cast<const VkImportFenceWin32HandleInfoKHR*>( &importFenceWin32HandleInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::importFenceWin32HandleKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getFenceFdKHR( const FenceGetFdInfoKHR* pGetFdInfo, int* pFd, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetFenceFdKHR( m_device, reinterpret_cast<const VkFenceGetFdInfoKHR*>( pGetFdInfo ), pFd ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<int>::type Device::getFenceFdKHR( const FenceGetFdInfoKHR & getFdInfo, Dispatch const &d ) const\r
+ {\r
+ int fd;\r
+ Result result = static_cast<Result>( d.vkGetFenceFdKHR( m_device, reinterpret_cast<const VkFenceGetFdInfoKHR*>( &getFdInfo ), &fd ) );\r
+ return createResultValue( result, fd, VULKAN_HPP_NAMESPACE_STRING"::Device::getFenceFdKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::importFenceFdKHR( const ImportFenceFdInfoKHR* pImportFenceFdInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkImportFenceFdKHR( m_device, reinterpret_cast<const VkImportFenceFdInfoKHR*>( pImportFenceFdInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::importFenceFdKHR( const ImportFenceFdInfoKHR & importFenceFdInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkImportFenceFdKHR( m_device, reinterpret_cast<const VkImportFenceFdInfoKHR*>( &importFenceFdInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::importFenceFdKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::displayPowerControlEXT( DisplayKHR display, const DisplayPowerInfoEXT* pDisplayPowerInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkDisplayPowerControlEXT( m_device, static_cast<VkDisplayKHR>( display ), reinterpret_cast<const VkDisplayPowerInfoEXT*>( pDisplayPowerInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::displayPowerControlEXT( DisplayKHR display, const DisplayPowerInfoEXT & displayPowerInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkDisplayPowerControlEXT( m_device, static_cast<VkDisplayKHR>( display ), reinterpret_cast<const VkDisplayPowerInfoEXT*>( &displayPowerInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::displayPowerControlEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::registerEventEXT( const DeviceEventInfoEXT* pDeviceEventInfo, const AllocationCallbacks* pAllocator, Fence* pFence, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkRegisterDeviceEventEXT( m_device, reinterpret_cast<const VkDeviceEventInfoEXT*>( pDeviceEventInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkFence*>( pFence ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Fence>::type Device::registerEventEXT( const DeviceEventInfoEXT & deviceEventInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Fence fence;\r
+ Result result = static_cast<Result>( d.vkRegisterDeviceEventEXT( m_device, reinterpret_cast<const VkDeviceEventInfoEXT*>( &deviceEventInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkFence*>( &fence ) ) );\r
+ return createResultValue( result, fence, VULKAN_HPP_NAMESPACE_STRING"::Device::registerEventEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::registerDisplayEventEXT( DisplayKHR display, const DisplayEventInfoEXT* pDisplayEventInfo, const AllocationCallbacks* pAllocator, Fence* pFence, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkRegisterDisplayEventEXT( m_device, static_cast<VkDisplayKHR>( display ), reinterpret_cast<const VkDisplayEventInfoEXT*>( pDisplayEventInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkFence*>( pFence ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Fence>::type Device::registerDisplayEventEXT( DisplayKHR display, const DisplayEventInfoEXT & displayEventInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Fence fence;\r
+ Result result = static_cast<Result>( d.vkRegisterDisplayEventEXT( m_device, static_cast<VkDisplayKHR>( display ), reinterpret_cast<const VkDisplayEventInfoEXT*>( &displayEventInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkFence*>( &fence ) ) );\r
+ return createResultValue( result, fence, VULKAN_HPP_NAMESPACE_STRING"::Device::registerDisplayEventEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getSwapchainCounterEXT( SwapchainKHR swapchain, SurfaceCounterFlagBitsEXT counter, uint64_t* pCounterValue, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetSwapchainCounterEXT( m_device, static_cast<VkSwapchainKHR>( swapchain ), static_cast<VkSurfaceCounterFlagBitsEXT>( counter ), pCounterValue ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<uint64_t>::type Device::getSwapchainCounterEXT( SwapchainKHR swapchain, SurfaceCounterFlagBitsEXT counter, Dispatch const &d ) const\r
+ {\r
+ uint64_t counterValue;\r
+ Result result = static_cast<Result>( d.vkGetSwapchainCounterEXT( m_device, static_cast<VkSwapchainKHR>( swapchain ), static_cast<VkSurfaceCounterFlagBitsEXT>( counter ), &counterValue ) );\r
+ return createResultValue( result, counterValue, VULKAN_HPP_NAMESPACE_STRING"::Device::getSwapchainCounterEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getGroupPeerMemoryFeatures( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, PeerMemoryFeatureFlags* pPeerMemoryFeatures, Dispatch const &d) const\r
+ {\r
+ d.vkGetDeviceGroupPeerMemoryFeatures( m_device, heapIndex, localDeviceIndex, remoteDeviceIndex, reinterpret_cast<VkPeerMemoryFeatureFlags*>( pPeerMemoryFeatures ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PeerMemoryFeatureFlags Device::getGroupPeerMemoryFeatures( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, Dispatch const &d ) const\r
+ {\r
+ PeerMemoryFeatureFlags peerMemoryFeatures;\r
+ d.vkGetDeviceGroupPeerMemoryFeatures( m_device, heapIndex, localDeviceIndex, remoteDeviceIndex, reinterpret_cast<VkPeerMemoryFeatureFlags*>( &peerMemoryFeatures ) );\r
+ return peerMemoryFeatures;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getGroupPeerMemoryFeaturesKHR( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, PeerMemoryFeatureFlags* pPeerMemoryFeatures, Dispatch const &d) const\r
+ {\r
+ d.vkGetDeviceGroupPeerMemoryFeaturesKHR( m_device, heapIndex, localDeviceIndex, remoteDeviceIndex, reinterpret_cast<VkPeerMemoryFeatureFlags*>( pPeerMemoryFeatures ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PeerMemoryFeatureFlags Device::getGroupPeerMemoryFeaturesKHR( uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, Dispatch const &d ) const\r
+ {\r
+ PeerMemoryFeatureFlags peerMemoryFeatures;\r
+ d.vkGetDeviceGroupPeerMemoryFeaturesKHR( m_device, heapIndex, localDeviceIndex, remoteDeviceIndex, reinterpret_cast<VkPeerMemoryFeatureFlags*>( &peerMemoryFeatures ) );\r
+ return peerMemoryFeatures;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::bindBufferMemory2( uint32_t bindInfoCount, const BindBufferMemoryInfo* pBindInfos, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBindBufferMemory2( m_device, bindInfoCount, reinterpret_cast<const VkBindBufferMemoryInfo*>( pBindInfos ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::bindBufferMemory2( ArrayProxy<const BindBufferMemoryInfo> bindInfos, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBindBufferMemory2( m_device, bindInfos.size() , reinterpret_cast<const VkBindBufferMemoryInfo*>( bindInfos.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::bindBufferMemory2" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::bindBufferMemory2KHR( uint32_t bindInfoCount, const BindBufferMemoryInfo* pBindInfos, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBindBufferMemory2KHR( m_device, bindInfoCount, reinterpret_cast<const VkBindBufferMemoryInfo*>( pBindInfos ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::bindBufferMemory2KHR( ArrayProxy<const BindBufferMemoryInfo> bindInfos, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBindBufferMemory2KHR( m_device, bindInfos.size() , reinterpret_cast<const VkBindBufferMemoryInfo*>( bindInfos.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::bindBufferMemory2KHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::bindImageMemory2( uint32_t bindInfoCount, const BindImageMemoryInfo* pBindInfos, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBindImageMemory2( m_device, bindInfoCount, reinterpret_cast<const VkBindImageMemoryInfo*>( pBindInfos ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::bindImageMemory2( ArrayProxy<const BindImageMemoryInfo> bindInfos, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBindImageMemory2( m_device, bindInfos.size() , reinterpret_cast<const VkBindImageMemoryInfo*>( bindInfos.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::bindImageMemory2" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::bindImageMemory2KHR( uint32_t bindInfoCount, const BindImageMemoryInfo* pBindInfos, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkBindImageMemory2KHR( m_device, bindInfoCount, reinterpret_cast<const VkBindImageMemoryInfo*>( pBindInfos ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::bindImageMemory2KHR( ArrayProxy<const BindImageMemoryInfo> bindInfos, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkBindImageMemory2KHR( m_device, bindInfos.size() , reinterpret_cast<const VkBindImageMemoryInfo*>( bindInfos.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::bindImageMemory2KHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getGroupPresentCapabilitiesKHR( DeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetDeviceGroupPresentCapabilitiesKHR( m_device, reinterpret_cast<VkDeviceGroupPresentCapabilitiesKHR*>( pDeviceGroupPresentCapabilities ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DeviceGroupPresentCapabilitiesKHR>::type Device::getGroupPresentCapabilitiesKHR(Dispatch const &d ) const\r
+ {\r
+ DeviceGroupPresentCapabilitiesKHR deviceGroupPresentCapabilities;\r
+ Result result = static_cast<Result>( d.vkGetDeviceGroupPresentCapabilitiesKHR( m_device, reinterpret_cast<VkDeviceGroupPresentCapabilitiesKHR*>( &deviceGroupPresentCapabilities ) ) );\r
+ return createResultValue( result, deviceGroupPresentCapabilities, VULKAN_HPP_NAMESPACE_STRING"::Device::getGroupPresentCapabilitiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getGroupSurfacePresentModesKHR( SurfaceKHR surface, DeviceGroupPresentModeFlagsKHR* pModes, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetDeviceGroupSurfacePresentModesKHR( m_device, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<VkDeviceGroupPresentModeFlagsKHR*>( pModes ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DeviceGroupPresentModeFlagsKHR>::type Device::getGroupSurfacePresentModesKHR( SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ DeviceGroupPresentModeFlagsKHR modes;\r
+ Result result = static_cast<Result>( d.vkGetDeviceGroupSurfacePresentModesKHR( m_device, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<VkDeviceGroupPresentModeFlagsKHR*>( &modes ) ) );\r
+ return createResultValue( result, modes, VULKAN_HPP_NAMESPACE_STRING"::Device::getGroupSurfacePresentModesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::acquireNextImage2KHR( const AcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkAcquireNextImage2KHR( m_device, reinterpret_cast<const VkAcquireNextImageInfoKHR*>( pAcquireInfo ), pImageIndex ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValue<uint32_t> Device::acquireNextImage2KHR( const AcquireNextImageInfoKHR & acquireInfo, Dispatch const &d ) const\r
+ {\r
+ uint32_t imageIndex;\r
+ Result result = static_cast<Result>( d.vkAcquireNextImage2KHR( m_device, reinterpret_cast<const VkAcquireNextImageInfoKHR*>( &acquireInfo ), &imageIndex ) );\r
+ return createResultValue( result, imageIndex, VULKAN_HPP_NAMESPACE_STRING"::Device::acquireNextImage2KHR", { Result::eSuccess, Result::eTimeout, Result::eNotReady, Result::eSuboptimalKHR } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createDescriptorUpdateTemplate( const DescriptorUpdateTemplateCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorUpdateTemplate* pDescriptorUpdateTemplate, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDescriptorUpdateTemplate( m_device, reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDescriptorUpdateTemplate*>( pDescriptorUpdateTemplate ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DescriptorUpdateTemplate>::type Device::createDescriptorUpdateTemplate( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorUpdateTemplate descriptorUpdateTemplate;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorUpdateTemplate( m_device, reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorUpdateTemplate*>( &descriptorUpdateTemplate ) ) );\r
+ return createResultValue( result, descriptorUpdateTemplate, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorUpdateTemplate" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDescriptorUpdateTemplate>::type Device::createDescriptorUpdateTemplateUnique( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorUpdateTemplate descriptorUpdateTemplate;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorUpdateTemplate( m_device, reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorUpdateTemplate*>( &descriptorUpdateTemplate ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, descriptorUpdateTemplate, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorUpdateTemplateUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createDescriptorUpdateTemplateKHR( const DescriptorUpdateTemplateCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, DescriptorUpdateTemplate* pDescriptorUpdateTemplate, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDescriptorUpdateTemplateKHR( m_device, reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDescriptorUpdateTemplate*>( pDescriptorUpdateTemplate ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DescriptorUpdateTemplate>::type Device::createDescriptorUpdateTemplateKHR( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorUpdateTemplate descriptorUpdateTemplate;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorUpdateTemplateKHR( m_device, reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorUpdateTemplate*>( &descriptorUpdateTemplate ) ) );\r
+ return createResultValue( result, descriptorUpdateTemplate, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorUpdateTemplateKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDescriptorUpdateTemplate>::type Device::createDescriptorUpdateTemplateKHRUnique( const DescriptorUpdateTemplateCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DescriptorUpdateTemplate descriptorUpdateTemplate;\r
+ Result result = static_cast<Result>( d.vkCreateDescriptorUpdateTemplateKHR( m_device, reinterpret_cast<const VkDescriptorUpdateTemplateCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDescriptorUpdateTemplate*>( &descriptorUpdateTemplate ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, descriptorUpdateTemplate, VULKAN_HPP_NAMESPACE_STRING"::Device::createDescriptorUpdateTemplateKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorUpdateTemplate( DescriptorUpdateTemplate descriptorUpdateTemplate, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorUpdateTemplate( m_device, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorUpdateTemplate( DescriptorUpdateTemplate descriptorUpdateTemplate, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorUpdateTemplate( m_device, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( DescriptorUpdateTemplate descriptorUpdateTemplate, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorUpdateTemplate( m_device, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( DescriptorUpdateTemplate descriptorUpdateTemplate, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorUpdateTemplate( m_device, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorUpdateTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDescriptorUpdateTemplateKHR( m_device, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyDescriptorUpdateTemplateKHR( DescriptorUpdateTemplate descriptorUpdateTemplate, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDescriptorUpdateTemplateKHR( m_device, static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::updateDescriptorSetWithTemplate( DescriptorSet descriptorSet, DescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData, Dispatch const &d) const\r
+ {\r
+ d.vkUpdateDescriptorSetWithTemplate( m_device, static_cast<VkDescriptorSet>( descriptorSet ), static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), pData );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::updateDescriptorSetWithTemplate( DescriptorSet descriptorSet, DescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData, Dispatch const &d ) const\r
+ {\r
+ d.vkUpdateDescriptorSetWithTemplate( m_device, static_cast<VkDescriptorSet>( descriptorSet ), static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), pData );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::updateDescriptorSetWithTemplateKHR( DescriptorSet descriptorSet, DescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData, Dispatch const &d) const\r
+ {\r
+ d.vkUpdateDescriptorSetWithTemplateKHR( m_device, static_cast<VkDescriptorSet>( descriptorSet ), static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), pData );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::updateDescriptorSetWithTemplateKHR( DescriptorSet descriptorSet, DescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData, Dispatch const &d ) const\r
+ {\r
+ d.vkUpdateDescriptorSetWithTemplateKHR( m_device, static_cast<VkDescriptorSet>( descriptorSet ), static_cast<VkDescriptorUpdateTemplate>( descriptorUpdateTemplate ), pData );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::setHdrMetadataEXT( uint32_t swapchainCount, const SwapchainKHR* pSwapchains, const HdrMetadataEXT* pMetadata, Dispatch const &d) const\r
+ {\r
+ d.vkSetHdrMetadataEXT( m_device, swapchainCount, reinterpret_cast<const VkSwapchainKHR*>( pSwapchains ), reinterpret_cast<const VkHdrMetadataEXT*>( pMetadata ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::setHdrMetadataEXT( ArrayProxy<const SwapchainKHR> swapchains, ArrayProxy<const HdrMetadataEXT> metadata, Dispatch const &d ) const\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( swapchains.size() == metadata.size() );\r
+#else\r
+ if ( swapchains.size() != metadata.size() )\r
+ {\r
+ throw LogicError( VULKAN_HPP_NAMESPACE_STRING "::Device::setHdrMetadataEXT: swapchains.size() != metadata.size()" );\r
+ }\r
+#endif // VULKAN_HPP_NO_EXCEPTIONS\r
+ d.vkSetHdrMetadataEXT( m_device, swapchains.size() , reinterpret_cast<const VkSwapchainKHR*>( swapchains.data() ), reinterpret_cast<const VkHdrMetadataEXT*>( metadata.data() ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getSwapchainStatusKHR( SwapchainKHR swapchain, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetSwapchainStatusKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getSwapchainStatusKHR( SwapchainKHR swapchain, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkGetSwapchainStatusKHR( m_device, static_cast<VkSwapchainKHR>( swapchain ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::getSwapchainStatusKHR", { Result::eSuccess, Result::eSuboptimalKHR } );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getRefreshCycleDurationGOOGLE( SwapchainKHR swapchain, RefreshCycleDurationGOOGLE* pDisplayTimingProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetRefreshCycleDurationGOOGLE( m_device, static_cast<VkSwapchainKHR>( swapchain ), reinterpret_cast<VkRefreshCycleDurationGOOGLE*>( pDisplayTimingProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<RefreshCycleDurationGOOGLE>::type Device::getRefreshCycleDurationGOOGLE( SwapchainKHR swapchain, Dispatch const &d ) const\r
+ {\r
+ RefreshCycleDurationGOOGLE displayTimingProperties;\r
+ Result result = static_cast<Result>( d.vkGetRefreshCycleDurationGOOGLE( m_device, static_cast<VkSwapchainKHR>( swapchain ), reinterpret_cast<VkRefreshCycleDurationGOOGLE*>( &displayTimingProperties ) ) );\r
+ return createResultValue( result, displayTimingProperties, VULKAN_HPP_NAMESPACE_STRING"::Device::getRefreshCycleDurationGOOGLE" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getPastPresentationTimingGOOGLE( SwapchainKHR swapchain, uint32_t* pPresentationTimingCount, PastPresentationTimingGOOGLE* pPresentationTimings, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPastPresentationTimingGOOGLE( m_device, static_cast<VkSwapchainKHR>( swapchain ), pPresentationTimingCount, reinterpret_cast<VkPastPresentationTimingGOOGLE*>( pPresentationTimings ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<PastPresentationTimingGOOGLE,Allocator>>::type Device::getPastPresentationTimingGOOGLE( SwapchainKHR swapchain, Dispatch const &d ) const\r
+ {\r
+ std::vector<PastPresentationTimingGOOGLE,Allocator> presentationTimings;\r
+ uint32_t presentationTimingCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPastPresentationTimingGOOGLE( m_device, static_cast<VkSwapchainKHR>( swapchain ), &presentationTimingCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && presentationTimingCount )\r
+ {\r
+ presentationTimings.resize( presentationTimingCount );\r
+ result = static_cast<Result>( d.vkGetPastPresentationTimingGOOGLE( m_device, static_cast<VkSwapchainKHR>( swapchain ), &presentationTimingCount, reinterpret_cast<VkPastPresentationTimingGOOGLE*>( presentationTimings.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( presentationTimingCount <= presentationTimings.size() );\r
+ presentationTimings.resize( presentationTimingCount );\r
+ return createResultValue( result, presentationTimings, VULKAN_HPP_NAMESPACE_STRING"::Device::getPastPresentationTimingGOOGLE" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getBufferMemoryRequirements2( const BufferMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetBufferMemoryRequirements2( m_device, reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>( pInfo ), reinterpret_cast<VkMemoryRequirements2*>( pMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MemoryRequirements2 Device::getBufferMemoryRequirements2( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ MemoryRequirements2 memoryRequirements;\r
+ d.vkGetBufferMemoryRequirements2( m_device, reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return memoryRequirements;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> Device::getBufferMemoryRequirements2( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ MemoryRequirements2& memoryRequirements = structureChain.template get<MemoryRequirements2>();\r
+ d.vkGetBufferMemoryRequirements2( m_device, reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getBufferMemoryRequirements2KHR( const BufferMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetBufferMemoryRequirements2KHR( m_device, reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>( pInfo ), reinterpret_cast<VkMemoryRequirements2*>( pMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MemoryRequirements2 Device::getBufferMemoryRequirements2KHR( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ MemoryRequirements2 memoryRequirements;\r
+ d.vkGetBufferMemoryRequirements2KHR( m_device, reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return memoryRequirements;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> Device::getBufferMemoryRequirements2KHR( const BufferMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ MemoryRequirements2& memoryRequirements = structureChain.template get<MemoryRequirements2>();\r
+ d.vkGetBufferMemoryRequirements2KHR( m_device, reinterpret_cast<const VkBufferMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageMemoryRequirements2( const ImageMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageMemoryRequirements2( m_device, reinterpret_cast<const VkImageMemoryRequirementsInfo2*>( pInfo ), reinterpret_cast<VkMemoryRequirements2*>( pMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MemoryRequirements2 Device::getImageMemoryRequirements2( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ MemoryRequirements2 memoryRequirements;\r
+ d.vkGetImageMemoryRequirements2( m_device, reinterpret_cast<const VkImageMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return memoryRequirements;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> Device::getImageMemoryRequirements2( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ MemoryRequirements2& memoryRequirements = structureChain.template get<MemoryRequirements2>();\r
+ d.vkGetImageMemoryRequirements2( m_device, reinterpret_cast<const VkImageMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageMemoryRequirements2KHR( const ImageMemoryRequirementsInfo2* pInfo, MemoryRequirements2* pMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageMemoryRequirements2KHR( m_device, reinterpret_cast<const VkImageMemoryRequirementsInfo2*>( pInfo ), reinterpret_cast<VkMemoryRequirements2*>( pMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MemoryRequirements2 Device::getImageMemoryRequirements2KHR( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ MemoryRequirements2 memoryRequirements;\r
+ d.vkGetImageMemoryRequirements2KHR( m_device, reinterpret_cast<const VkImageMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return memoryRequirements;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> Device::getImageMemoryRequirements2KHR( const ImageMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ MemoryRequirements2& memoryRequirements = structureChain.template get<MemoryRequirements2>();\r
+ d.vkGetImageMemoryRequirements2KHR( m_device, reinterpret_cast<const VkImageMemoryRequirementsInfo2*>( &info ), reinterpret_cast<VkMemoryRequirements2*>( &memoryRequirements ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageSparseMemoryRequirements2( const ImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, SparseImageMemoryRequirements2* pSparseMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageSparseMemoryRequirements2( m_device, reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>( pInfo ), pSparseMemoryRequirementCount, reinterpret_cast<VkSparseImageMemoryRequirements2*>( pSparseMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<SparseImageMemoryRequirements2,Allocator> Device::getImageSparseMemoryRequirements2( const ImageSparseMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ std::vector<SparseImageMemoryRequirements2,Allocator> sparseMemoryRequirements;\r
+ uint32_t sparseMemoryRequirementCount;\r
+ d.vkGetImageSparseMemoryRequirements2( m_device, reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>( &info ), &sparseMemoryRequirementCount, nullptr );\r
+ sparseMemoryRequirements.resize( sparseMemoryRequirementCount );\r
+ d.vkGetImageSparseMemoryRequirements2( m_device, reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>( &info ), &sparseMemoryRequirementCount, reinterpret_cast<VkSparseImageMemoryRequirements2*>( sparseMemoryRequirements.data() ) );\r
+ return sparseMemoryRequirements;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getImageSparseMemoryRequirements2KHR( const ImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, SparseImageMemoryRequirements2* pSparseMemoryRequirements, Dispatch const &d) const\r
+ {\r
+ d.vkGetImageSparseMemoryRequirements2KHR( m_device, reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>( pInfo ), pSparseMemoryRequirementCount, reinterpret_cast<VkSparseImageMemoryRequirements2*>( pSparseMemoryRequirements ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<SparseImageMemoryRequirements2,Allocator> Device::getImageSparseMemoryRequirements2KHR( const ImageSparseMemoryRequirementsInfo2 & info, Dispatch const &d ) const\r
+ {\r
+ std::vector<SparseImageMemoryRequirements2,Allocator> sparseMemoryRequirements;\r
+ uint32_t sparseMemoryRequirementCount;\r
+ d.vkGetImageSparseMemoryRequirements2KHR( m_device, reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>( &info ), &sparseMemoryRequirementCount, nullptr );\r
+ sparseMemoryRequirements.resize( sparseMemoryRequirementCount );\r
+ d.vkGetImageSparseMemoryRequirements2KHR( m_device, reinterpret_cast<const VkImageSparseMemoryRequirementsInfo2*>( &info ), &sparseMemoryRequirementCount, reinterpret_cast<VkSparseImageMemoryRequirements2*>( sparseMemoryRequirements.data() ) );\r
+ return sparseMemoryRequirements;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createSamplerYcbcrConversion( const SamplerYcbcrConversionCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, SamplerYcbcrConversion* pYcbcrConversion, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateSamplerYcbcrConversion( m_device, reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSamplerYcbcrConversion*>( pYcbcrConversion ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SamplerYcbcrConversion>::type Device::createSamplerYcbcrConversion( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SamplerYcbcrConversion ycbcrConversion;\r
+ Result result = static_cast<Result>( d.vkCreateSamplerYcbcrConversion( m_device, reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSamplerYcbcrConversion*>( &ycbcrConversion ) ) );\r
+ return createResultValue( result, ycbcrConversion, VULKAN_HPP_NAMESPACE_STRING"::Device::createSamplerYcbcrConversion" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSamplerYcbcrConversion>::type Device::createSamplerYcbcrConversionUnique( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SamplerYcbcrConversion ycbcrConversion;\r
+ Result result = static_cast<Result>( d.vkCreateSamplerYcbcrConversion( m_device, reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSamplerYcbcrConversion*>( &ycbcrConversion ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, ycbcrConversion, VULKAN_HPP_NAMESPACE_STRING"::Device::createSamplerYcbcrConversionUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createSamplerYcbcrConversionKHR( const SamplerYcbcrConversionCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, SamplerYcbcrConversion* pYcbcrConversion, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateSamplerYcbcrConversionKHR( m_device, reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSamplerYcbcrConversion*>( pYcbcrConversion ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SamplerYcbcrConversion>::type Device::createSamplerYcbcrConversionKHR( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SamplerYcbcrConversion ycbcrConversion;\r
+ Result result = static_cast<Result>( d.vkCreateSamplerYcbcrConversionKHR( m_device, reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSamplerYcbcrConversion*>( &ycbcrConversion ) ) );\r
+ return createResultValue( result, ycbcrConversion, VULKAN_HPP_NAMESPACE_STRING"::Device::createSamplerYcbcrConversionKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSamplerYcbcrConversion>::type Device::createSamplerYcbcrConversionKHRUnique( const SamplerYcbcrConversionCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SamplerYcbcrConversion ycbcrConversion;\r
+ Result result = static_cast<Result>( d.vkCreateSamplerYcbcrConversionKHR( m_device, reinterpret_cast<const VkSamplerYcbcrConversionCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSamplerYcbcrConversion*>( &ycbcrConversion ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, ycbcrConversion, VULKAN_HPP_NAMESPACE_STRING"::Device::createSamplerYcbcrConversionKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySamplerYcbcrConversion( SamplerYcbcrConversion ycbcrConversion, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySamplerYcbcrConversion( m_device, static_cast<VkSamplerYcbcrConversion>( ycbcrConversion ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySamplerYcbcrConversion( SamplerYcbcrConversion ycbcrConversion, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySamplerYcbcrConversion( m_device, static_cast<VkSamplerYcbcrConversion>( ycbcrConversion ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( SamplerYcbcrConversion ycbcrConversion, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySamplerYcbcrConversion( m_device, static_cast<VkSamplerYcbcrConversion>( ycbcrConversion ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( SamplerYcbcrConversion ycbcrConversion, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySamplerYcbcrConversion( m_device, static_cast<VkSamplerYcbcrConversion>( ycbcrConversion ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySamplerYcbcrConversionKHR( SamplerYcbcrConversion ycbcrConversion, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySamplerYcbcrConversionKHR( m_device, static_cast<VkSamplerYcbcrConversion>( ycbcrConversion ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroySamplerYcbcrConversionKHR( SamplerYcbcrConversion ycbcrConversion, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySamplerYcbcrConversionKHR( m_device, static_cast<VkSamplerYcbcrConversion>( ycbcrConversion ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getQueue2( const DeviceQueueInfo2* pQueueInfo, Queue* pQueue, Dispatch const &d) const\r
+ {\r
+ d.vkGetDeviceQueue2( m_device, reinterpret_cast<const VkDeviceQueueInfo2*>( pQueueInfo ), reinterpret_cast<VkQueue*>( pQueue ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Queue Device::getQueue2( const DeviceQueueInfo2 & queueInfo, Dispatch const &d ) const\r
+ {\r
+ Queue queue;\r
+ d.vkGetDeviceQueue2( m_device, reinterpret_cast<const VkDeviceQueueInfo2*>( &queueInfo ), reinterpret_cast<VkQueue*>( &queue ) );\r
+ return queue;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::createValidationCacheEXT( const ValidationCacheCreateInfoEXT* pCreateInfo, const AllocationCallbacks* pAllocator, ValidationCacheEXT* pValidationCache, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateValidationCacheEXT( m_device, reinterpret_cast<const VkValidationCacheCreateInfoEXT*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkValidationCacheEXT*>( pValidationCache ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ValidationCacheEXT>::type Device::createValidationCacheEXT( const ValidationCacheCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ValidationCacheEXT validationCache;\r
+ Result result = static_cast<Result>( d.vkCreateValidationCacheEXT( m_device, reinterpret_cast<const VkValidationCacheCreateInfoEXT*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkValidationCacheEXT*>( &validationCache ) ) );\r
+ return createResultValue( result, validationCache, VULKAN_HPP_NAMESPACE_STRING"::Device::createValidationCacheEXT" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueValidationCacheEXT>::type Device::createValidationCacheEXTUnique( const ValidationCacheCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ ValidationCacheEXT validationCache;\r
+ Result result = static_cast<Result>( d.vkCreateValidationCacheEXT( m_device, reinterpret_cast<const VkValidationCacheCreateInfoEXT*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkValidationCacheEXT*>( &validationCache ) ) );\r
+\r
+ ObjectDestroy<Device> deleter( *this, allocator );\r
+ return createResultValue( result, validationCache, VULKAN_HPP_NAMESPACE_STRING"::Device::createValidationCacheEXTUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyValidationCacheEXT( ValidationCacheEXT validationCache, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyValidationCacheEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroyValidationCacheEXT( ValidationCacheEXT validationCache, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyValidationCacheEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ValidationCacheEXT validationCache, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyValidationCacheEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::destroy( ValidationCacheEXT validationCache, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyValidationCacheEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getValidationCacheDataEXT( ValidationCacheEXT validationCache, size_t* pDataSize, void* pData, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetValidationCacheDataEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), pDataSize, pData ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<uint8_t,Allocator>>::type Device::getValidationCacheDataEXT( ValidationCacheEXT validationCache, Dispatch const &d ) const\r
+ {\r
+ std::vector<uint8_t,Allocator> data;\r
+ size_t dataSize;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetValidationCacheDataEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), &dataSize, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && dataSize )\r
+ {\r
+ data.resize( dataSize );\r
+ result = static_cast<Result>( d.vkGetValidationCacheDataEXT( m_device, static_cast<VkValidationCacheEXT>( validationCache ), &dataSize, reinterpret_cast<void*>( data.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( dataSize <= data.size() );\r
+ data.resize( dataSize );\r
+ return createResultValue( result, data, VULKAN_HPP_NAMESPACE_STRING"::Device::getValidationCacheDataEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::mergeValidationCachesEXT( ValidationCacheEXT dstCache, uint32_t srcCacheCount, const ValidationCacheEXT* pSrcCaches, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkMergeValidationCachesEXT( m_device, static_cast<VkValidationCacheEXT>( dstCache ), srcCacheCount, reinterpret_cast<const VkValidationCacheEXT*>( pSrcCaches ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::mergeValidationCachesEXT( ValidationCacheEXT dstCache, ArrayProxy<const ValidationCacheEXT> srcCaches, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkMergeValidationCachesEXT( m_device, static_cast<VkValidationCacheEXT>( dstCache ), srcCaches.size() , reinterpret_cast<const VkValidationCacheEXT*>( srcCaches.data() ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::mergeValidationCachesEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getDescriptorSetLayoutSupport( const DescriptorSetLayoutCreateInfo* pCreateInfo, DescriptorSetLayoutSupport* pSupport, Dispatch const &d) const\r
+ {\r
+ d.vkGetDescriptorSetLayoutSupport( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( pCreateInfo ), reinterpret_cast<VkDescriptorSetLayoutSupport*>( pSupport ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE DescriptorSetLayoutSupport Device::getDescriptorSetLayoutSupport( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d ) const\r
+ {\r
+ DescriptorSetLayoutSupport support;\r
+ d.vkGetDescriptorSetLayoutSupport( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( &createInfo ), reinterpret_cast<VkDescriptorSetLayoutSupport*>( &support ) );\r
+ return support;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> Device::getDescriptorSetLayoutSupport( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ DescriptorSetLayoutSupport& support = structureChain.template get<DescriptorSetLayoutSupport>();\r
+ d.vkGetDescriptorSetLayoutSupport( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( &createInfo ), reinterpret_cast<VkDescriptorSetLayoutSupport*>( &support ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Device::getDescriptorSetLayoutSupportKHR( const DescriptorSetLayoutCreateInfo* pCreateInfo, DescriptorSetLayoutSupport* pSupport, Dispatch const &d) const\r
+ {\r
+ d.vkGetDescriptorSetLayoutSupportKHR( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( pCreateInfo ), reinterpret_cast<VkDescriptorSetLayoutSupport*>( pSupport ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE DescriptorSetLayoutSupport Device::getDescriptorSetLayoutSupportKHR( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d ) const\r
+ {\r
+ DescriptorSetLayoutSupport support;\r
+ d.vkGetDescriptorSetLayoutSupportKHR( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( &createInfo ), reinterpret_cast<VkDescriptorSetLayoutSupport*>( &support ) );\r
+ return support;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> Device::getDescriptorSetLayoutSupportKHR( const DescriptorSetLayoutCreateInfo & createInfo, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ DescriptorSetLayoutSupport& support = structureChain.template get<DescriptorSetLayoutSupport>();\r
+ d.vkGetDescriptorSetLayoutSupportKHR( m_device, reinterpret_cast<const VkDescriptorSetLayoutCreateInfo*>( &createInfo ), reinterpret_cast<VkDescriptorSetLayoutSupport*>( &support ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getShaderInfoAMD( Pipeline pipeline, ShaderStageFlagBits shaderStage, ShaderInfoTypeAMD infoType, size_t* pInfoSize, void* pInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetShaderInfoAMD( m_device, static_cast<VkPipeline>( pipeline ), static_cast<VkShaderStageFlagBits>( shaderStage ), static_cast<VkShaderInfoTypeAMD>( infoType ), pInfoSize, pInfo ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<uint8_t,Allocator>>::type Device::getShaderInfoAMD( Pipeline pipeline, ShaderStageFlagBits shaderStage, ShaderInfoTypeAMD infoType, Dispatch const &d ) const\r
+ {\r
+ std::vector<uint8_t,Allocator> info;\r
+ size_t infoSize;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetShaderInfoAMD( m_device, static_cast<VkPipeline>( pipeline ), static_cast<VkShaderStageFlagBits>( shaderStage ), static_cast<VkShaderInfoTypeAMD>( infoType ), &infoSize, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && infoSize )\r
+ {\r
+ info.resize( infoSize );\r
+ result = static_cast<Result>( d.vkGetShaderInfoAMD( m_device, static_cast<VkPipeline>( pipeline ), static_cast<VkShaderStageFlagBits>( shaderStage ), static_cast<VkShaderInfoTypeAMD>( infoType ), &infoSize, reinterpret_cast<void*>( info.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( infoSize <= info.size() );\r
+ info.resize( infoSize );\r
+ return createResultValue( result, info, VULKAN_HPP_NAMESPACE_STRING"::Device::getShaderInfoAMD" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::setDebugUtilsObjectNameEXT( const DebugUtilsObjectNameInfoEXT* pNameInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkSetDebugUtilsObjectNameEXT( m_device, reinterpret_cast<const VkDebugUtilsObjectNameInfoEXT*>( pNameInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::setDebugUtilsObjectNameEXT( const DebugUtilsObjectNameInfoEXT & nameInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkSetDebugUtilsObjectNameEXT( m_device, reinterpret_cast<const VkDebugUtilsObjectNameInfoEXT*>( &nameInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::setDebugUtilsObjectNameEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::setDebugUtilsObjectTagEXT( const DebugUtilsObjectTagInfoEXT* pTagInfo, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkSetDebugUtilsObjectTagEXT( m_device, reinterpret_cast<const VkDebugUtilsObjectTagInfoEXT*>( pTagInfo ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type Device::setDebugUtilsObjectTagEXT( const DebugUtilsObjectTagInfoEXT & tagInfo, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkSetDebugUtilsObjectTagEXT( m_device, reinterpret_cast<const VkDebugUtilsObjectTagInfoEXT*>( &tagInfo ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::Device::setDebugUtilsObjectTagEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryHostPointerPropertiesEXT( ExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, MemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryHostPointerPropertiesEXT( m_device, static_cast<VkExternalMemoryHandleTypeFlagBits>( handleType ), pHostPointer, reinterpret_cast<VkMemoryHostPointerPropertiesEXT*>( pMemoryHostPointerProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<MemoryHostPointerPropertiesEXT>::type Device::getMemoryHostPointerPropertiesEXT( ExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, Dispatch const &d ) const\r
+ {\r
+ MemoryHostPointerPropertiesEXT memoryHostPointerProperties;\r
+ Result result = static_cast<Result>( d.vkGetMemoryHostPointerPropertiesEXT( m_device, static_cast<VkExternalMemoryHandleTypeFlagBits>( handleType ), pHostPointer, reinterpret_cast<VkMemoryHostPointerPropertiesEXT*>( &memoryHostPointerProperties ) ) );\r
+ return createResultValue( result, memoryHostPointerProperties, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryHostPointerPropertiesEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getAndroidHardwareBufferPropertiesANDROID( const struct AHardwareBuffer* buffer, AndroidHardwareBufferPropertiesANDROID* pProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetAndroidHardwareBufferPropertiesANDROID( m_device, buffer, reinterpret_cast<VkAndroidHardwareBufferPropertiesANDROID*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<AndroidHardwareBufferPropertiesANDROID>::type Device::getAndroidHardwareBufferPropertiesANDROID( const struct AHardwareBuffer & buffer, Dispatch const &d ) const\r
+ {\r
+ AndroidHardwareBufferPropertiesANDROID properties;\r
+ Result result = static_cast<Result>( d.vkGetAndroidHardwareBufferPropertiesANDROID( m_device, buffer, reinterpret_cast<VkAndroidHardwareBufferPropertiesANDROID*>( &properties ) ) );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::Device::getAndroidHardwareBufferPropertiesANDROID" );\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE typename ResultValueType<StructureChain<T...>>::type Device::getAndroidHardwareBufferPropertiesANDROID( const struct AHardwareBuffer & buffer, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ AndroidHardwareBufferPropertiesANDROID& properties = structureChain.template get<AndroidHardwareBufferPropertiesANDROID>();\r
+ Result result = static_cast<Result>( d.vkGetAndroidHardwareBufferPropertiesANDROID( m_device, buffer, reinterpret_cast<VkAndroidHardwareBufferPropertiesANDROID*>( &properties ) ) );\r
+ return createResultValue( result, structureChain, VULKAN_HPP_NAMESPACE_STRING"::Device::getAndroidHardwareBufferPropertiesANDROID" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Device::getMemoryAndroidHardwareBufferANDROID( const MemoryGetAndroidHardwareBufferInfoANDROID* pInfo, struct AHardwareBuffer** pBuffer, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetMemoryAndroidHardwareBufferANDROID( m_device, reinterpret_cast<const VkMemoryGetAndroidHardwareBufferInfoANDROID*>( pInfo ), pBuffer ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<struct AHardwareBuffer*>::type Device::getMemoryAndroidHardwareBufferANDROID( const MemoryGetAndroidHardwareBufferInfoANDROID & info, Dispatch const &d ) const\r
+ {\r
+ struct AHardwareBuffer* buffer;\r
+ Result result = static_cast<Result>( d.vkGetMemoryAndroidHardwareBufferANDROID( m_device, reinterpret_cast<const VkMemoryGetAndroidHardwareBufferInfoANDROID*>( &info ), &buffer ) );\r
+ return createResultValue( result, buffer, VULKAN_HPP_NAMESPACE_STRING"::Device::getMemoryAndroidHardwareBufferANDROID" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+\r
+ template <> class UniqueHandleTraits<Device> {public: using deleter = ObjectDestroy<NoParent>; };\r
+ using UniqueDevice = UniqueHandle<Device>;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+\r
+ class PhysicalDevice\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR PhysicalDevice()\r
+ : m_physicalDevice(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR PhysicalDevice( std::nullptr_t )\r
+ : m_physicalDevice(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT PhysicalDevice( VkPhysicalDevice physicalDevice )\r
+ : m_physicalDevice( physicalDevice )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ PhysicalDevice & operator=(VkPhysicalDevice physicalDevice)\r
+ {\r
+ m_physicalDevice = physicalDevice;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ PhysicalDevice & operator=( std::nullptr_t )\r
+ {\r
+ m_physicalDevice = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( PhysicalDevice const & rhs ) const\r
+ {\r
+ return m_physicalDevice == rhs.m_physicalDevice;\r
+ }\r
+\r
+ bool operator!=(PhysicalDevice const & rhs ) const\r
+ {\r
+ return m_physicalDevice != rhs.m_physicalDevice;\r
+ }\r
+\r
+ bool operator<(PhysicalDevice const & rhs ) const\r
+ {\r
+ return m_physicalDevice < rhs.m_physicalDevice;\r
+ }\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getProperties( PhysicalDeviceProperties* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceProperties getProperties(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getQueueFamilyProperties( uint32_t* pQueueFamilyPropertyCount, QueueFamilyProperties* pQueueFamilyProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<QueueFamilyProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<QueueFamilyProperties,Allocator> getQueueFamilyProperties(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getMemoryProperties( PhysicalDeviceMemoryProperties* pMemoryProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceMemoryProperties getMemoryProperties(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getFeatures( PhysicalDeviceFeatures* pFeatures, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceFeatures getFeatures(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getFormatProperties( Format format, FormatProperties* pFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ FormatProperties getFormatProperties( Format format, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getImageFormatProperties( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, ImageFormatProperties* pImageFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ImageFormatProperties>::type getImageFormatProperties( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDevice( const DeviceCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Device* pDevice, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Device>::type createDevice( const DeviceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDevice>::type createDeviceUnique( const DeviceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumerateDeviceLayerProperties( uint32_t* pPropertyCount, LayerProperties* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<LayerProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<LayerProperties,Allocator>>::type enumerateDeviceLayerProperties(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumerateDeviceExtensionProperties( const char* pLayerName, uint32_t* pPropertyCount, ExtensionProperties* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<ExtensionProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<ExtensionProperties,Allocator>>::type enumerateDeviceExtensionProperties( Optional<const std::string> layerName = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getSparseImageFormatProperties( Format format, ImageType type, SampleCountFlagBits samples, ImageUsageFlags usage, ImageTiling tiling, uint32_t* pPropertyCount, SparseImageFormatProperties* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SparseImageFormatProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<SparseImageFormatProperties,Allocator> getSparseImageFormatProperties( Format format, ImageType type, SampleCountFlagBits samples, ImageUsageFlags usage, ImageTiling tiling, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getDisplayPropertiesKHR( uint32_t* pPropertyCount, DisplayPropertiesKHR* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<DisplayPropertiesKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<DisplayPropertiesKHR,Allocator>>::type getDisplayPropertiesKHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getDisplayPlanePropertiesKHR( uint32_t* pPropertyCount, DisplayPlanePropertiesKHR* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<DisplayPlanePropertiesKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<DisplayPlanePropertiesKHR,Allocator>>::type getDisplayPlanePropertiesKHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getDisplayPlaneSupportedDisplaysKHR( uint32_t planeIndex, uint32_t* pDisplayCount, DisplayKHR* pDisplays, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<DisplayKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<DisplayKHR,Allocator>>::type getDisplayPlaneSupportedDisplaysKHR( uint32_t planeIndex, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getDisplayModePropertiesKHR( DisplayKHR display, uint32_t* pPropertyCount, DisplayModePropertiesKHR* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<DisplayModePropertiesKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<DisplayModePropertiesKHR,Allocator>>::type getDisplayModePropertiesKHR( DisplayKHR display, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDisplayModeKHR( DisplayKHR display, const DisplayModeCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, DisplayModeKHR* pMode, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DisplayModeKHR>::type createDisplayModeKHR( DisplayKHR display, const DisplayModeCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getDisplayPlaneCapabilitiesKHR( DisplayModeKHR mode, uint32_t planeIndex, DisplayPlaneCapabilitiesKHR* pCapabilities, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DisplayPlaneCapabilitiesKHR>::type getDisplayPlaneCapabilitiesKHR( DisplayModeKHR mode, uint32_t planeIndex, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getMirPresentationSupportKHR( uint32_t queueFamilyIndex, MirConnection* connection, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getMirPresentationSupportKHR( uint32_t queueFamilyIndex, MirConnection & connection, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfaceSupportKHR( uint32_t queueFamilyIndex, SurfaceKHR surface, Bool32* pSupported, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Bool32>::type getSurfaceSupportKHR( uint32_t queueFamilyIndex, SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfaceCapabilitiesKHR( SurfaceKHR surface, SurfaceCapabilitiesKHR* pSurfaceCapabilities, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceCapabilitiesKHR>::type getSurfaceCapabilitiesKHR( SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfaceFormatsKHR( SurfaceKHR surface, uint32_t* pSurfaceFormatCount, SurfaceFormatKHR* pSurfaceFormats, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SurfaceFormatKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<SurfaceFormatKHR,Allocator>>::type getSurfaceFormatsKHR( SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfacePresentModesKHR( SurfaceKHR surface, uint32_t* pPresentModeCount, PresentModeKHR* pPresentModes, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<PresentModeKHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<PresentModeKHR,Allocator>>::type getSurfacePresentModesKHR( SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getWaylandPresentationSupportKHR( uint32_t queueFamilyIndex, struct wl_display* display, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getWaylandPresentationSupportKHR( uint32_t queueFamilyIndex, struct wl_display & display, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getWin32PresentationSupportKHR( uint32_t queueFamilyIndex, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getXlibPresentationSupportKHR( uint32_t queueFamilyIndex, Display* dpy, VisualID visualID, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getXlibPresentationSupportKHR( uint32_t queueFamilyIndex, Display & dpy, VisualID visualID, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getXcbPresentationSupportKHR( uint32_t queueFamilyIndex, xcb_connection_t* connection, xcb_visualid_t visual_id, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Bool32 getXcbPresentationSupportKHR( uint32_t queueFamilyIndex, xcb_connection_t & connection, xcb_visualid_t visual_id, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getExternalImageFormatPropertiesNV( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, ExternalMemoryHandleTypeFlagsNV externalHandleType, ExternalImageFormatPropertiesNV* pExternalImageFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ExternalImageFormatPropertiesNV>::type getExternalImageFormatPropertiesNV( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, ExternalMemoryHandleTypeFlagsNV externalHandleType, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getGeneratedCommandsPropertiesNVX( DeviceGeneratedCommandsFeaturesNVX* pFeatures, DeviceGeneratedCommandsLimitsNVX* pLimits, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ DeviceGeneratedCommandsLimitsNVX getGeneratedCommandsPropertiesNVX( DeviceGeneratedCommandsFeaturesNVX & features, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getFeatures2( PhysicalDeviceFeatures2* pFeatures, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceFeatures2 getFeatures2(Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getFeatures2(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getFeatures2KHR( PhysicalDeviceFeatures2* pFeatures, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceFeatures2 getFeatures2KHR(Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getFeatures2KHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getProperties2( PhysicalDeviceProperties2* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceProperties2 getProperties2(Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getProperties2(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getProperties2KHR( PhysicalDeviceProperties2* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceProperties2 getProperties2KHR(Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ StructureChain<T...> getProperties2KHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getFormatProperties2( Format format, FormatProperties2* pFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ FormatProperties2 getFormatProperties2( Format format, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getFormatProperties2KHR( Format format, FormatProperties2* pFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ FormatProperties2 getFormatProperties2KHR( Format format, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getImageFormatProperties2( const PhysicalDeviceImageFormatInfo2* pImageFormatInfo, ImageFormatProperties2* pImageFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ImageFormatProperties2>::type getImageFormatProperties2( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ typename ResultValueType<StructureChain<T...>>::type getImageFormatProperties2( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getImageFormatProperties2KHR( const PhysicalDeviceImageFormatInfo2* pImageFormatInfo, ImageFormatProperties2* pImageFormatProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<ImageFormatProperties2>::type getImageFormatProperties2KHR( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ typename ResultValueType<StructureChain<T...>>::type getImageFormatProperties2KHR( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getQueueFamilyProperties2( uint32_t* pQueueFamilyPropertyCount, QueueFamilyProperties2* pQueueFamilyProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<QueueFamilyProperties2>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<QueueFamilyProperties2,Allocator> getQueueFamilyProperties2(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getQueueFamilyProperties2KHR( uint32_t* pQueueFamilyPropertyCount, QueueFamilyProperties2* pQueueFamilyProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<QueueFamilyProperties2>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<QueueFamilyProperties2,Allocator> getQueueFamilyProperties2KHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getMemoryProperties2( PhysicalDeviceMemoryProperties2* pMemoryProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceMemoryProperties2 getMemoryProperties2(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getMemoryProperties2KHR( PhysicalDeviceMemoryProperties2* pMemoryProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PhysicalDeviceMemoryProperties2 getMemoryProperties2KHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getSparseImageFormatProperties2( const PhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, SparseImageFormatProperties2* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SparseImageFormatProperties2>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<SparseImageFormatProperties2,Allocator> getSparseImageFormatProperties2( const PhysicalDeviceSparseImageFormatInfo2 & formatInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getSparseImageFormatProperties2KHR( const PhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, SparseImageFormatProperties2* pProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SparseImageFormatProperties2>, typename Dispatch = DispatchLoaderStatic> \r
+ std::vector<SparseImageFormatProperties2,Allocator> getSparseImageFormatProperties2KHR( const PhysicalDeviceSparseImageFormatInfo2 & formatInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getExternalBufferProperties( const PhysicalDeviceExternalBufferInfo* pExternalBufferInfo, ExternalBufferProperties* pExternalBufferProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ExternalBufferProperties getExternalBufferProperties( const PhysicalDeviceExternalBufferInfo & externalBufferInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getExternalBufferPropertiesKHR( const PhysicalDeviceExternalBufferInfo* pExternalBufferInfo, ExternalBufferProperties* pExternalBufferProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ExternalBufferProperties getExternalBufferPropertiesKHR( const PhysicalDeviceExternalBufferInfo & externalBufferInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getExternalSemaphoreProperties( const PhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, ExternalSemaphoreProperties* pExternalSemaphoreProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ExternalSemaphoreProperties getExternalSemaphoreProperties( const PhysicalDeviceExternalSemaphoreInfo & externalSemaphoreInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getExternalSemaphorePropertiesKHR( const PhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, ExternalSemaphoreProperties* pExternalSemaphoreProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ExternalSemaphoreProperties getExternalSemaphorePropertiesKHR( const PhysicalDeviceExternalSemaphoreInfo & externalSemaphoreInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getExternalFenceProperties( const PhysicalDeviceExternalFenceInfo* pExternalFenceInfo, ExternalFenceProperties* pExternalFenceProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ExternalFenceProperties getExternalFenceProperties( const PhysicalDeviceExternalFenceInfo & externalFenceInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getExternalFencePropertiesKHR( const PhysicalDeviceExternalFenceInfo* pExternalFenceInfo, ExternalFenceProperties* pExternalFenceProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ExternalFenceProperties getExternalFencePropertiesKHR( const PhysicalDeviceExternalFenceInfo & externalFenceInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result releaseDisplayEXT( DisplayKHR display, Dispatch const &d = Dispatch() ) const;\r
+#else\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<void>::type releaseDisplayEXT( DisplayKHR display, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result acquireXlibDisplayEXT( Display* dpy, DisplayKHR display, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Display>::type acquireXlibDisplayEXT( DisplayKHR display, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getRandROutputDisplayEXT( Display* dpy, RROutput rrOutput, DisplayKHR* pDisplay, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DisplayKHR>::type getRandROutputDisplayEXT( Display & dpy, RROutput rrOutput, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfaceCapabilities2EXT( SurfaceKHR surface, SurfaceCapabilities2EXT* pSurfaceCapabilities, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceCapabilities2EXT>::type getSurfaceCapabilities2EXT( SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getPresentRectanglesKHR( SurfaceKHR surface, uint32_t* pRectCount, Rect2D* pRects, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<Rect2D>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<Rect2D,Allocator>>::type getPresentRectanglesKHR( SurfaceKHR surface, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void getMultisamplePropertiesEXT( SampleCountFlagBits samples, MultisamplePropertiesEXT* pMultisampleProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ MultisamplePropertiesEXT getMultisamplePropertiesEXT( SampleCountFlagBits samples, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfaceCapabilities2KHR( const PhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, SurfaceCapabilities2KHR* pSurfaceCapabilities, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceCapabilities2KHR>::type getSurfaceCapabilities2KHR( const PhysicalDeviceSurfaceInfo2KHR & surfaceInfo, Dispatch const &d = Dispatch() ) const;\r
+ template <typename ...T, typename Dispatch = DispatchLoaderStatic>\r
+ typename ResultValueType<StructureChain<T...>>::type getSurfaceCapabilities2KHR( const PhysicalDeviceSurfaceInfo2KHR & surfaceInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result getSurfaceFormats2KHR( const PhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, uint32_t* pSurfaceFormatCount, SurfaceFormat2KHR* pSurfaceFormats, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<SurfaceFormat2KHR>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<SurfaceFormat2KHR,Allocator>>::type getSurfaceFormats2KHR( const PhysicalDeviceSurfaceInfo2KHR & surfaceInfo, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkPhysicalDevice() const\r
+ {\r
+ return m_physicalDevice;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_physicalDevice != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_physicalDevice == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkPhysicalDevice m_physicalDevice;\r
+ };\r
+\r
+ static_assert( sizeof( PhysicalDevice ) == sizeof( VkPhysicalDevice ), "handle and wrapper have different size!" );\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getProperties( PhysicalDeviceProperties* pProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceProperties( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties*>( pProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceProperties PhysicalDevice::getProperties(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceProperties properties;\r
+ d.vkGetPhysicalDeviceProperties( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties*>( &properties ) );\r
+ return properties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getQueueFamilyProperties( uint32_t* pQueueFamilyPropertyCount, QueueFamilyProperties* pQueueFamilyProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties( m_physicalDevice, pQueueFamilyPropertyCount, reinterpret_cast<VkQueueFamilyProperties*>( pQueueFamilyProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<QueueFamilyProperties,Allocator> PhysicalDevice::getQueueFamilyProperties(Dispatch const &d ) const\r
+ {\r
+ std::vector<QueueFamilyProperties,Allocator> queueFamilyProperties;\r
+ uint32_t queueFamilyPropertyCount;\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties( m_physicalDevice, &queueFamilyPropertyCount, nullptr );\r
+ queueFamilyProperties.resize( queueFamilyPropertyCount );\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties( m_physicalDevice, &queueFamilyPropertyCount, reinterpret_cast<VkQueueFamilyProperties*>( queueFamilyProperties.data() ) );\r
+ return queueFamilyProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getMemoryProperties( PhysicalDeviceMemoryProperties* pMemoryProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceMemoryProperties( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceMemoryProperties*>( pMemoryProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceMemoryProperties PhysicalDevice::getMemoryProperties(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceMemoryProperties memoryProperties;\r
+ d.vkGetPhysicalDeviceMemoryProperties( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceMemoryProperties*>( &memoryProperties ) );\r
+ return memoryProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getFeatures( PhysicalDeviceFeatures* pFeatures, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceFeatures( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures*>( pFeatures ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceFeatures PhysicalDevice::getFeatures(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceFeatures features;\r
+ d.vkGetPhysicalDeviceFeatures( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures*>( &features ) );\r
+ return features;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getFormatProperties( Format format, FormatProperties* pFormatProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), reinterpret_cast<VkFormatProperties*>( pFormatProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE FormatProperties PhysicalDevice::getFormatProperties( Format format, Dispatch const &d ) const\r
+ {\r
+ FormatProperties formatProperties;\r
+ d.vkGetPhysicalDeviceFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), reinterpret_cast<VkFormatProperties*>( &formatProperties ) );\r
+ return formatProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getImageFormatProperties( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, ImageFormatProperties* pImageFormatProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkImageTiling>( tiling ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageCreateFlags>( flags ), reinterpret_cast<VkImageFormatProperties*>( pImageFormatProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ImageFormatProperties>::type PhysicalDevice::getImageFormatProperties( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, Dispatch const &d ) const\r
+ {\r
+ ImageFormatProperties imageFormatProperties;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkImageTiling>( tiling ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageCreateFlags>( flags ), reinterpret_cast<VkImageFormatProperties*>( &imageFormatProperties ) ) );\r
+ return createResultValue( result, imageFormatProperties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getImageFormatProperties" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::createDevice( const DeviceCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Device* pDevice, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDevice( m_physicalDevice, reinterpret_cast<const VkDeviceCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDevice*>( pDevice ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Device>::type PhysicalDevice::createDevice( const DeviceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Device device;\r
+ Result result = static_cast<Result>( d.vkCreateDevice( m_physicalDevice, reinterpret_cast<const VkDeviceCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDevice*>( &device ) ) );\r
+ return createResultValue( result, device, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::createDevice" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDevice>::type PhysicalDevice::createDeviceUnique( const DeviceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ Device device;\r
+ Result result = static_cast<Result>( d.vkCreateDevice( m_physicalDevice, reinterpret_cast<const VkDeviceCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDevice*>( &device ) ) );\r
+\r
+ ObjectDestroy<NoParent> deleter( allocator );\r
+ return createResultValue( result, device, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::createDeviceUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::enumerateDeviceLayerProperties( uint32_t* pPropertyCount, LayerProperties* pProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkEnumerateDeviceLayerProperties( m_physicalDevice, pPropertyCount, reinterpret_cast<VkLayerProperties*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<LayerProperties,Allocator>>::type PhysicalDevice::enumerateDeviceLayerProperties(Dispatch const &d ) const\r
+ {\r
+ std::vector<LayerProperties,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumerateDeviceLayerProperties( m_physicalDevice, &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkEnumerateDeviceLayerProperties( m_physicalDevice, &propertyCount, reinterpret_cast<VkLayerProperties*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::enumerateDeviceLayerProperties" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::enumerateDeviceExtensionProperties( const char* pLayerName, uint32_t* pPropertyCount, ExtensionProperties* pProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkEnumerateDeviceExtensionProperties( m_physicalDevice, pLayerName, pPropertyCount, reinterpret_cast<VkExtensionProperties*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<ExtensionProperties,Allocator>>::type PhysicalDevice::enumerateDeviceExtensionProperties( Optional<const std::string> layerName, Dispatch const &d ) const\r
+ {\r
+ std::vector<ExtensionProperties,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumerateDeviceExtensionProperties( m_physicalDevice, layerName ? layerName->c_str() : nullptr, &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkEnumerateDeviceExtensionProperties( m_physicalDevice, layerName ? layerName->c_str() : nullptr, &propertyCount, reinterpret_cast<VkExtensionProperties*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::enumerateDeviceExtensionProperties" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getSparseImageFormatProperties( Format format, ImageType type, SampleCountFlagBits samples, ImageUsageFlags usage, ImageTiling tiling, uint32_t* pPropertyCount, SparseImageFormatProperties* pProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkSampleCountFlagBits>( samples ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageTiling>( tiling ), pPropertyCount, reinterpret_cast<VkSparseImageFormatProperties*>( pProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<SparseImageFormatProperties,Allocator> PhysicalDevice::getSparseImageFormatProperties( Format format, ImageType type, SampleCountFlagBits samples, ImageUsageFlags usage, ImageTiling tiling, Dispatch const &d ) const\r
+ {\r
+ std::vector<SparseImageFormatProperties,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkSampleCountFlagBits>( samples ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageTiling>( tiling ), &propertyCount, nullptr );\r
+ properties.resize( propertyCount );\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkSampleCountFlagBits>( samples ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageTiling>( tiling ), &propertyCount, reinterpret_cast<VkSparseImageFormatProperties*>( properties.data() ) );\r
+ return properties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getDisplayPropertiesKHR( uint32_t* pPropertyCount, DisplayPropertiesKHR* pProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceDisplayPropertiesKHR( m_physicalDevice, pPropertyCount, reinterpret_cast<VkDisplayPropertiesKHR*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<DisplayPropertiesKHR,Allocator>>::type PhysicalDevice::getDisplayPropertiesKHR(Dispatch const &d ) const\r
+ {\r
+ std::vector<DisplayPropertiesKHR,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceDisplayPropertiesKHR( m_physicalDevice, &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceDisplayPropertiesKHR( m_physicalDevice, &propertyCount, reinterpret_cast<VkDisplayPropertiesKHR*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getDisplayPropertiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getDisplayPlanePropertiesKHR( uint32_t* pPropertyCount, DisplayPlanePropertiesKHR* pProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceDisplayPlanePropertiesKHR( m_physicalDevice, pPropertyCount, reinterpret_cast<VkDisplayPlanePropertiesKHR*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<DisplayPlanePropertiesKHR,Allocator>>::type PhysicalDevice::getDisplayPlanePropertiesKHR(Dispatch const &d ) const\r
+ {\r
+ std::vector<DisplayPlanePropertiesKHR,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceDisplayPlanePropertiesKHR( m_physicalDevice, &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceDisplayPlanePropertiesKHR( m_physicalDevice, &propertyCount, reinterpret_cast<VkDisplayPlanePropertiesKHR*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getDisplayPlanePropertiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getDisplayPlaneSupportedDisplaysKHR( uint32_t planeIndex, uint32_t* pDisplayCount, DisplayKHR* pDisplays, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetDisplayPlaneSupportedDisplaysKHR( m_physicalDevice, planeIndex, pDisplayCount, reinterpret_cast<VkDisplayKHR*>( pDisplays ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<DisplayKHR,Allocator>>::type PhysicalDevice::getDisplayPlaneSupportedDisplaysKHR( uint32_t planeIndex, Dispatch const &d ) const\r
+ {\r
+ std::vector<DisplayKHR,Allocator> displays;\r
+ uint32_t displayCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetDisplayPlaneSupportedDisplaysKHR( m_physicalDevice, planeIndex, &displayCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && displayCount )\r
+ {\r
+ displays.resize( displayCount );\r
+ result = static_cast<Result>( d.vkGetDisplayPlaneSupportedDisplaysKHR( m_physicalDevice, planeIndex, &displayCount, reinterpret_cast<VkDisplayKHR*>( displays.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( displayCount <= displays.size() );\r
+ displays.resize( displayCount );\r
+ return createResultValue( result, displays, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getDisplayPlaneSupportedDisplaysKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getDisplayModePropertiesKHR( DisplayKHR display, uint32_t* pPropertyCount, DisplayModePropertiesKHR* pProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetDisplayModePropertiesKHR( m_physicalDevice, static_cast<VkDisplayKHR>( display ), pPropertyCount, reinterpret_cast<VkDisplayModePropertiesKHR*>( pProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<DisplayModePropertiesKHR,Allocator>>::type PhysicalDevice::getDisplayModePropertiesKHR( DisplayKHR display, Dispatch const &d ) const\r
+ {\r
+ std::vector<DisplayModePropertiesKHR,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetDisplayModePropertiesKHR( m_physicalDevice, static_cast<VkDisplayKHR>( display ), &propertyCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && propertyCount )\r
+ {\r
+ properties.resize( propertyCount );\r
+ result = static_cast<Result>( d.vkGetDisplayModePropertiesKHR( m_physicalDevice, static_cast<VkDisplayKHR>( display ), &propertyCount, reinterpret_cast<VkDisplayModePropertiesKHR*>( properties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( propertyCount <= properties.size() );\r
+ properties.resize( propertyCount );\r
+ return createResultValue( result, properties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getDisplayModePropertiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::createDisplayModeKHR( DisplayKHR display, const DisplayModeCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, DisplayModeKHR* pMode, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDisplayModeKHR( m_physicalDevice, static_cast<VkDisplayKHR>( display ), reinterpret_cast<const VkDisplayModeCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDisplayModeKHR*>( pMode ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DisplayModeKHR>::type PhysicalDevice::createDisplayModeKHR( DisplayKHR display, const DisplayModeCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DisplayModeKHR mode;\r
+ Result result = static_cast<Result>( d.vkCreateDisplayModeKHR( m_physicalDevice, static_cast<VkDisplayKHR>( display ), reinterpret_cast<const VkDisplayModeCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDisplayModeKHR*>( &mode ) ) );\r
+ return createResultValue( result, mode, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::createDisplayModeKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getDisplayPlaneCapabilitiesKHR( DisplayModeKHR mode, uint32_t planeIndex, DisplayPlaneCapabilitiesKHR* pCapabilities, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetDisplayPlaneCapabilitiesKHR( m_physicalDevice, static_cast<VkDisplayModeKHR>( mode ), planeIndex, reinterpret_cast<VkDisplayPlaneCapabilitiesKHR*>( pCapabilities ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DisplayPlaneCapabilitiesKHR>::type PhysicalDevice::getDisplayPlaneCapabilitiesKHR( DisplayModeKHR mode, uint32_t planeIndex, Dispatch const &d ) const\r
+ {\r
+ DisplayPlaneCapabilitiesKHR capabilities;\r
+ Result result = static_cast<Result>( d.vkGetDisplayPlaneCapabilitiesKHR( m_physicalDevice, static_cast<VkDisplayModeKHR>( mode ), planeIndex, reinterpret_cast<VkDisplayPlaneCapabilitiesKHR*>( &capabilities ) ) );\r
+ return createResultValue( result, capabilities, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getDisplayPlaneCapabilitiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getMirPresentationSupportKHR( uint32_t queueFamilyIndex, MirConnection* connection, Dispatch const &d) const\r
+ {\r
+ return d.vkGetPhysicalDeviceMirPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, connection );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getMirPresentationSupportKHR( uint32_t queueFamilyIndex, MirConnection & connection, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetPhysicalDeviceMirPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, &connection );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfaceSupportKHR( uint32_t queueFamilyIndex, SurfaceKHR surface, Bool32* pSupported, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfaceSupportKHR( m_physicalDevice, queueFamilyIndex, static_cast<VkSurfaceKHR>( surface ), pSupported ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Bool32>::type PhysicalDevice::getSurfaceSupportKHR( uint32_t queueFamilyIndex, SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ Bool32 supported;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceSupportKHR( m_physicalDevice, queueFamilyIndex, static_cast<VkSurfaceKHR>( surface ), &supported ) );\r
+ return createResultValue( result, supported, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceSupportKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfaceCapabilitiesKHR( SurfaceKHR surface, SurfaceCapabilitiesKHR* pSurfaceCapabilities, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilitiesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<VkSurfaceCapabilitiesKHR*>( pSurfaceCapabilities ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceCapabilitiesKHR>::type PhysicalDevice::getSurfaceCapabilitiesKHR( SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ SurfaceCapabilitiesKHR surfaceCapabilities;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilitiesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<VkSurfaceCapabilitiesKHR*>( &surfaceCapabilities ) ) );\r
+ return createResultValue( result, surfaceCapabilities, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceCapabilitiesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfaceFormatsKHR( SurfaceKHR surface, uint32_t* pSurfaceFormatCount, SurfaceFormatKHR* pSurfaceFormats, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfaceFormatsKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), pSurfaceFormatCount, reinterpret_cast<VkSurfaceFormatKHR*>( pSurfaceFormats ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<SurfaceFormatKHR,Allocator>>::type PhysicalDevice::getSurfaceFormatsKHR( SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ std::vector<SurfaceFormatKHR,Allocator> surfaceFormats;\r
+ uint32_t surfaceFormatCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceFormatsKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), &surfaceFormatCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && surfaceFormatCount )\r
+ {\r
+ surfaceFormats.resize( surfaceFormatCount );\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceFormatsKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), &surfaceFormatCount, reinterpret_cast<VkSurfaceFormatKHR*>( surfaceFormats.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( surfaceFormatCount <= surfaceFormats.size() );\r
+ surfaceFormats.resize( surfaceFormatCount );\r
+ return createResultValue( result, surfaceFormats, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceFormatsKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfacePresentModesKHR( SurfaceKHR surface, uint32_t* pPresentModeCount, PresentModeKHR* pPresentModes, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfacePresentModesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), pPresentModeCount, reinterpret_cast<VkPresentModeKHR*>( pPresentModes ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<PresentModeKHR,Allocator>>::type PhysicalDevice::getSurfacePresentModesKHR( SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ std::vector<PresentModeKHR,Allocator> presentModes;\r
+ uint32_t presentModeCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceSurfacePresentModesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), &presentModeCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && presentModeCount )\r
+ {\r
+ presentModes.resize( presentModeCount );\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceSurfacePresentModesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), &presentModeCount, reinterpret_cast<VkPresentModeKHR*>( presentModes.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( presentModeCount <= presentModes.size() );\r
+ presentModes.resize( presentModeCount );\r
+ return createResultValue( result, presentModes, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfacePresentModesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getWaylandPresentationSupportKHR( uint32_t queueFamilyIndex, struct wl_display* display, Dispatch const &d) const\r
+ {\r
+ return d.vkGetPhysicalDeviceWaylandPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, display );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getWaylandPresentationSupportKHR( uint32_t queueFamilyIndex, struct wl_display & display, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetPhysicalDeviceWaylandPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, &display );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getWin32PresentationSupportKHR( uint32_t queueFamilyIndex, Dispatch const &d) const\r
+ {\r
+ return d.vkGetPhysicalDeviceWin32PresentationSupportKHR( m_physicalDevice, queueFamilyIndex );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getWin32PresentationSupportKHR( uint32_t queueFamilyIndex, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetPhysicalDeviceWin32PresentationSupportKHR( m_physicalDevice, queueFamilyIndex );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getXlibPresentationSupportKHR( uint32_t queueFamilyIndex, Display* dpy, VisualID visualID, Dispatch const &d) const\r
+ {\r
+ return d.vkGetPhysicalDeviceXlibPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, dpy, visualID );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getXlibPresentationSupportKHR( uint32_t queueFamilyIndex, Display & dpy, VisualID visualID, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetPhysicalDeviceXlibPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, &dpy, visualID );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getXcbPresentationSupportKHR( uint32_t queueFamilyIndex, xcb_connection_t* connection, xcb_visualid_t visual_id, Dispatch const &d) const\r
+ {\r
+ return d.vkGetPhysicalDeviceXcbPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, connection, visual_id );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Bool32 PhysicalDevice::getXcbPresentationSupportKHR( uint32_t queueFamilyIndex, xcb_connection_t & connection, xcb_visualid_t visual_id, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetPhysicalDeviceXcbPresentationSupportKHR( m_physicalDevice, queueFamilyIndex, &connection, visual_id );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getExternalImageFormatPropertiesNV( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, ExternalMemoryHandleTypeFlagsNV externalHandleType, ExternalImageFormatPropertiesNV* pExternalImageFormatProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceExternalImageFormatPropertiesNV( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkImageTiling>( tiling ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageCreateFlags>( flags ), static_cast<VkExternalMemoryHandleTypeFlagsNV>( externalHandleType ), reinterpret_cast<VkExternalImageFormatPropertiesNV*>( pExternalImageFormatProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ExternalImageFormatPropertiesNV>::type PhysicalDevice::getExternalImageFormatPropertiesNV( Format format, ImageType type, ImageTiling tiling, ImageUsageFlags usage, ImageCreateFlags flags, ExternalMemoryHandleTypeFlagsNV externalHandleType, Dispatch const &d ) const\r
+ {\r
+ ExternalImageFormatPropertiesNV externalImageFormatProperties;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceExternalImageFormatPropertiesNV( m_physicalDevice, static_cast<VkFormat>( format ), static_cast<VkImageType>( type ), static_cast<VkImageTiling>( tiling ), static_cast<VkImageUsageFlags>( usage ), static_cast<VkImageCreateFlags>( flags ), static_cast<VkExternalMemoryHandleTypeFlagsNV>( externalHandleType ), reinterpret_cast<VkExternalImageFormatPropertiesNV*>( &externalImageFormatProperties ) ) );\r
+ return createResultValue( result, externalImageFormatProperties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getExternalImageFormatPropertiesNV" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getGeneratedCommandsPropertiesNVX( DeviceGeneratedCommandsFeaturesNVX* pFeatures, DeviceGeneratedCommandsLimitsNVX* pLimits, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX( m_physicalDevice, reinterpret_cast<VkDeviceGeneratedCommandsFeaturesNVX*>( pFeatures ), reinterpret_cast<VkDeviceGeneratedCommandsLimitsNVX*>( pLimits ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE DeviceGeneratedCommandsLimitsNVX PhysicalDevice::getGeneratedCommandsPropertiesNVX( DeviceGeneratedCommandsFeaturesNVX & features, Dispatch const &d ) const\r
+ {\r
+ DeviceGeneratedCommandsLimitsNVX limits;\r
+ d.vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX( m_physicalDevice, reinterpret_cast<VkDeviceGeneratedCommandsFeaturesNVX*>( &features ), reinterpret_cast<VkDeviceGeneratedCommandsLimitsNVX*>( &limits ) );\r
+ return limits;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getFeatures2( PhysicalDeviceFeatures2* pFeatures, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceFeatures2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures2*>( pFeatures ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceFeatures2 PhysicalDevice::getFeatures2(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceFeatures2 features;\r
+ d.vkGetPhysicalDeviceFeatures2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures2*>( &features ) );\r
+ return features;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> PhysicalDevice::getFeatures2(Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ PhysicalDeviceFeatures2& features = structureChain.template get<PhysicalDeviceFeatures2>();\r
+ d.vkGetPhysicalDeviceFeatures2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures2*>( &features ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getFeatures2KHR( PhysicalDeviceFeatures2* pFeatures, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceFeatures2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures2*>( pFeatures ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceFeatures2 PhysicalDevice::getFeatures2KHR(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceFeatures2 features;\r
+ d.vkGetPhysicalDeviceFeatures2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures2*>( &features ) );\r
+ return features;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> PhysicalDevice::getFeatures2KHR(Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ PhysicalDeviceFeatures2& features = structureChain.template get<PhysicalDeviceFeatures2>();\r
+ d.vkGetPhysicalDeviceFeatures2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceFeatures2*>( &features ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getProperties2( PhysicalDeviceProperties2* pProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceProperties2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties2*>( pProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceProperties2 PhysicalDevice::getProperties2(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceProperties2 properties;\r
+ d.vkGetPhysicalDeviceProperties2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties2*>( &properties ) );\r
+ return properties;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> PhysicalDevice::getProperties2(Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ PhysicalDeviceProperties2& properties = structureChain.template get<PhysicalDeviceProperties2>();\r
+ d.vkGetPhysicalDeviceProperties2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties2*>( &properties ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getProperties2KHR( PhysicalDeviceProperties2* pProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceProperties2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties2*>( pProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceProperties2 PhysicalDevice::getProperties2KHR(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceProperties2 properties;\r
+ d.vkGetPhysicalDeviceProperties2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties2*>( &properties ) );\r
+ return properties;\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE StructureChain<T...> PhysicalDevice::getProperties2KHR(Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ PhysicalDeviceProperties2& properties = structureChain.template get<PhysicalDeviceProperties2>();\r
+ d.vkGetPhysicalDeviceProperties2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceProperties2*>( &properties ) );\r
+ return structureChain;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getFormatProperties2( Format format, FormatProperties2* pFormatProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceFormatProperties2( m_physicalDevice, static_cast<VkFormat>( format ), reinterpret_cast<VkFormatProperties2*>( pFormatProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE FormatProperties2 PhysicalDevice::getFormatProperties2( Format format, Dispatch const &d ) const\r
+ {\r
+ FormatProperties2 formatProperties;\r
+ d.vkGetPhysicalDeviceFormatProperties2( m_physicalDevice, static_cast<VkFormat>( format ), reinterpret_cast<VkFormatProperties2*>( &formatProperties ) );\r
+ return formatProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getFormatProperties2KHR( Format format, FormatProperties2* pFormatProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceFormatProperties2KHR( m_physicalDevice, static_cast<VkFormat>( format ), reinterpret_cast<VkFormatProperties2*>( pFormatProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE FormatProperties2 PhysicalDevice::getFormatProperties2KHR( Format format, Dispatch const &d ) const\r
+ {\r
+ FormatProperties2 formatProperties;\r
+ d.vkGetPhysicalDeviceFormatProperties2KHR( m_physicalDevice, static_cast<VkFormat>( format ), reinterpret_cast<VkFormatProperties2*>( &formatProperties ) );\r
+ return formatProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getImageFormatProperties2( const PhysicalDeviceImageFormatInfo2* pImageFormatInfo, ImageFormatProperties2* pImageFormatProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties2( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>( pImageFormatInfo ), reinterpret_cast<VkImageFormatProperties2*>( pImageFormatProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ImageFormatProperties2>::type PhysicalDevice::getImageFormatProperties2( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d ) const\r
+ {\r
+ ImageFormatProperties2 imageFormatProperties;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties2( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>( &imageFormatInfo ), reinterpret_cast<VkImageFormatProperties2*>( &imageFormatProperties ) ) );\r
+ return createResultValue( result, imageFormatProperties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getImageFormatProperties2" );\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE typename ResultValueType<StructureChain<T...>>::type PhysicalDevice::getImageFormatProperties2( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ ImageFormatProperties2& imageFormatProperties = structureChain.template get<ImageFormatProperties2>();\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties2( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>( &imageFormatInfo ), reinterpret_cast<VkImageFormatProperties2*>( &imageFormatProperties ) ) );\r
+ return createResultValue( result, structureChain, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getImageFormatProperties2" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getImageFormatProperties2KHR( const PhysicalDeviceImageFormatInfo2* pImageFormatInfo, ImageFormatProperties2* pImageFormatProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>( pImageFormatInfo ), reinterpret_cast<VkImageFormatProperties2*>( pImageFormatProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<ImageFormatProperties2>::type PhysicalDevice::getImageFormatProperties2KHR( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d ) const\r
+ {\r
+ ImageFormatProperties2 imageFormatProperties;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>( &imageFormatInfo ), reinterpret_cast<VkImageFormatProperties2*>( &imageFormatProperties ) ) );\r
+ return createResultValue( result, imageFormatProperties, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getImageFormatProperties2KHR" );\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE typename ResultValueType<StructureChain<T...>>::type PhysicalDevice::getImageFormatProperties2KHR( const PhysicalDeviceImageFormatInfo2 & imageFormatInfo, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ ImageFormatProperties2& imageFormatProperties = structureChain.template get<ImageFormatProperties2>();\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceImageFormatProperties2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceImageFormatInfo2*>( &imageFormatInfo ), reinterpret_cast<VkImageFormatProperties2*>( &imageFormatProperties ) ) );\r
+ return createResultValue( result, structureChain, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getImageFormatProperties2KHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getQueueFamilyProperties2( uint32_t* pQueueFamilyPropertyCount, QueueFamilyProperties2* pQueueFamilyProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties2( m_physicalDevice, pQueueFamilyPropertyCount, reinterpret_cast<VkQueueFamilyProperties2*>( pQueueFamilyProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<QueueFamilyProperties2,Allocator> PhysicalDevice::getQueueFamilyProperties2(Dispatch const &d ) const\r
+ {\r
+ std::vector<QueueFamilyProperties2,Allocator> queueFamilyProperties;\r
+ uint32_t queueFamilyPropertyCount;\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties2( m_physicalDevice, &queueFamilyPropertyCount, nullptr );\r
+ queueFamilyProperties.resize( queueFamilyPropertyCount );\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties2( m_physicalDevice, &queueFamilyPropertyCount, reinterpret_cast<VkQueueFamilyProperties2*>( queueFamilyProperties.data() ) );\r
+ return queueFamilyProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getQueueFamilyProperties2KHR( uint32_t* pQueueFamilyPropertyCount, QueueFamilyProperties2* pQueueFamilyProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties2KHR( m_physicalDevice, pQueueFamilyPropertyCount, reinterpret_cast<VkQueueFamilyProperties2*>( pQueueFamilyProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<QueueFamilyProperties2,Allocator> PhysicalDevice::getQueueFamilyProperties2KHR(Dispatch const &d ) const\r
+ {\r
+ std::vector<QueueFamilyProperties2,Allocator> queueFamilyProperties;\r
+ uint32_t queueFamilyPropertyCount;\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties2KHR( m_physicalDevice, &queueFamilyPropertyCount, nullptr );\r
+ queueFamilyProperties.resize( queueFamilyPropertyCount );\r
+ d.vkGetPhysicalDeviceQueueFamilyProperties2KHR( m_physicalDevice, &queueFamilyPropertyCount, reinterpret_cast<VkQueueFamilyProperties2*>( queueFamilyProperties.data() ) );\r
+ return queueFamilyProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getMemoryProperties2( PhysicalDeviceMemoryProperties2* pMemoryProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceMemoryProperties2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceMemoryProperties2*>( pMemoryProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceMemoryProperties2 PhysicalDevice::getMemoryProperties2(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceMemoryProperties2 memoryProperties;\r
+ d.vkGetPhysicalDeviceMemoryProperties2( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceMemoryProperties2*>( &memoryProperties ) );\r
+ return memoryProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getMemoryProperties2KHR( PhysicalDeviceMemoryProperties2* pMemoryProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceMemoryProperties2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceMemoryProperties2*>( pMemoryProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PhysicalDeviceMemoryProperties2 PhysicalDevice::getMemoryProperties2KHR(Dispatch const &d ) const\r
+ {\r
+ PhysicalDeviceMemoryProperties2 memoryProperties;\r
+ d.vkGetPhysicalDeviceMemoryProperties2KHR( m_physicalDevice, reinterpret_cast<VkPhysicalDeviceMemoryProperties2*>( &memoryProperties ) );\r
+ return memoryProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getSparseImageFormatProperties2( const PhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, SparseImageFormatProperties2* pProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties2( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>( pFormatInfo ), pPropertyCount, reinterpret_cast<VkSparseImageFormatProperties2*>( pProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<SparseImageFormatProperties2,Allocator> PhysicalDevice::getSparseImageFormatProperties2( const PhysicalDeviceSparseImageFormatInfo2 & formatInfo, Dispatch const &d ) const\r
+ {\r
+ std::vector<SparseImageFormatProperties2,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties2( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>( &formatInfo ), &propertyCount, nullptr );\r
+ properties.resize( propertyCount );\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties2( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>( &formatInfo ), &propertyCount, reinterpret_cast<VkSparseImageFormatProperties2*>( properties.data() ) );\r
+ return properties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getSparseImageFormatProperties2KHR( const PhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, SparseImageFormatProperties2* pProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>( pFormatInfo ), pPropertyCount, reinterpret_cast<VkSparseImageFormatProperties2*>( pProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE std::vector<SparseImageFormatProperties2,Allocator> PhysicalDevice::getSparseImageFormatProperties2KHR( const PhysicalDeviceSparseImageFormatInfo2 & formatInfo, Dispatch const &d ) const\r
+ {\r
+ std::vector<SparseImageFormatProperties2,Allocator> properties;\r
+ uint32_t propertyCount;\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>( &formatInfo ), &propertyCount, nullptr );\r
+ properties.resize( propertyCount );\r
+ d.vkGetPhysicalDeviceSparseImageFormatProperties2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSparseImageFormatInfo2*>( &formatInfo ), &propertyCount, reinterpret_cast<VkSparseImageFormatProperties2*>( properties.data() ) );\r
+ return properties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getExternalBufferProperties( const PhysicalDeviceExternalBufferInfo* pExternalBufferInfo, ExternalBufferProperties* pExternalBufferProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceExternalBufferProperties( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalBufferInfo*>( pExternalBufferInfo ), reinterpret_cast<VkExternalBufferProperties*>( pExternalBufferProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ExternalBufferProperties PhysicalDevice::getExternalBufferProperties( const PhysicalDeviceExternalBufferInfo & externalBufferInfo, Dispatch const &d ) const\r
+ {\r
+ ExternalBufferProperties externalBufferProperties;\r
+ d.vkGetPhysicalDeviceExternalBufferProperties( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalBufferInfo*>( &externalBufferInfo ), reinterpret_cast<VkExternalBufferProperties*>( &externalBufferProperties ) );\r
+ return externalBufferProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getExternalBufferPropertiesKHR( const PhysicalDeviceExternalBufferInfo* pExternalBufferInfo, ExternalBufferProperties* pExternalBufferProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceExternalBufferPropertiesKHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalBufferInfo*>( pExternalBufferInfo ), reinterpret_cast<VkExternalBufferProperties*>( pExternalBufferProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ExternalBufferProperties PhysicalDevice::getExternalBufferPropertiesKHR( const PhysicalDeviceExternalBufferInfo & externalBufferInfo, Dispatch const &d ) const\r
+ {\r
+ ExternalBufferProperties externalBufferProperties;\r
+ d.vkGetPhysicalDeviceExternalBufferPropertiesKHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalBufferInfo*>( &externalBufferInfo ), reinterpret_cast<VkExternalBufferProperties*>( &externalBufferProperties ) );\r
+ return externalBufferProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getExternalSemaphoreProperties( const PhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, ExternalSemaphoreProperties* pExternalSemaphoreProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceExternalSemaphoreProperties( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalSemaphoreInfo*>( pExternalSemaphoreInfo ), reinterpret_cast<VkExternalSemaphoreProperties*>( pExternalSemaphoreProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ExternalSemaphoreProperties PhysicalDevice::getExternalSemaphoreProperties( const PhysicalDeviceExternalSemaphoreInfo & externalSemaphoreInfo, Dispatch const &d ) const\r
+ {\r
+ ExternalSemaphoreProperties externalSemaphoreProperties;\r
+ d.vkGetPhysicalDeviceExternalSemaphoreProperties( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalSemaphoreInfo*>( &externalSemaphoreInfo ), reinterpret_cast<VkExternalSemaphoreProperties*>( &externalSemaphoreProperties ) );\r
+ return externalSemaphoreProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getExternalSemaphorePropertiesKHR( const PhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, ExternalSemaphoreProperties* pExternalSemaphoreProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceExternalSemaphorePropertiesKHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalSemaphoreInfo*>( pExternalSemaphoreInfo ), reinterpret_cast<VkExternalSemaphoreProperties*>( pExternalSemaphoreProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ExternalSemaphoreProperties PhysicalDevice::getExternalSemaphorePropertiesKHR( const PhysicalDeviceExternalSemaphoreInfo & externalSemaphoreInfo, Dispatch const &d ) const\r
+ {\r
+ ExternalSemaphoreProperties externalSemaphoreProperties;\r
+ d.vkGetPhysicalDeviceExternalSemaphorePropertiesKHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalSemaphoreInfo*>( &externalSemaphoreInfo ), reinterpret_cast<VkExternalSemaphoreProperties*>( &externalSemaphoreProperties ) );\r
+ return externalSemaphoreProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getExternalFenceProperties( const PhysicalDeviceExternalFenceInfo* pExternalFenceInfo, ExternalFenceProperties* pExternalFenceProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceExternalFenceProperties( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalFenceInfo*>( pExternalFenceInfo ), reinterpret_cast<VkExternalFenceProperties*>( pExternalFenceProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ExternalFenceProperties PhysicalDevice::getExternalFenceProperties( const PhysicalDeviceExternalFenceInfo & externalFenceInfo, Dispatch const &d ) const\r
+ {\r
+ ExternalFenceProperties externalFenceProperties;\r
+ d.vkGetPhysicalDeviceExternalFenceProperties( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalFenceInfo*>( &externalFenceInfo ), reinterpret_cast<VkExternalFenceProperties*>( &externalFenceProperties ) );\r
+ return externalFenceProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getExternalFencePropertiesKHR( const PhysicalDeviceExternalFenceInfo* pExternalFenceInfo, ExternalFenceProperties* pExternalFenceProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceExternalFencePropertiesKHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalFenceInfo*>( pExternalFenceInfo ), reinterpret_cast<VkExternalFenceProperties*>( pExternalFenceProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ExternalFenceProperties PhysicalDevice::getExternalFencePropertiesKHR( const PhysicalDeviceExternalFenceInfo & externalFenceInfo, Dispatch const &d ) const\r
+ {\r
+ ExternalFenceProperties externalFenceProperties;\r
+ d.vkGetPhysicalDeviceExternalFencePropertiesKHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceExternalFenceInfo*>( &externalFenceInfo ), reinterpret_cast<VkExternalFenceProperties*>( &externalFenceProperties ) );\r
+ return externalFenceProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::releaseDisplayEXT( DisplayKHR display, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkReleaseDisplayEXT( m_physicalDevice, static_cast<VkDisplayKHR>( display ) ) );\r
+ }\r
+#else\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<void>::type PhysicalDevice::releaseDisplayEXT( DisplayKHR display, Dispatch const &d ) const\r
+ {\r
+ Result result = static_cast<Result>( d.vkReleaseDisplayEXT( m_physicalDevice, static_cast<VkDisplayKHR>( display ) ) );\r
+ return createResultValue( result, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::releaseDisplayEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::acquireXlibDisplayEXT( Display* dpy, DisplayKHR display, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkAcquireXlibDisplayEXT( m_physicalDevice, dpy, static_cast<VkDisplayKHR>( display ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Display>::type PhysicalDevice::acquireXlibDisplayEXT( DisplayKHR display, Dispatch const &d ) const\r
+ {\r
+ Display dpy;\r
+ Result result = static_cast<Result>( d.vkAcquireXlibDisplayEXT( m_physicalDevice, &dpy, static_cast<VkDisplayKHR>( display ) ) );\r
+ return createResultValue( result, dpy, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::acquireXlibDisplayEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getRandROutputDisplayEXT( Display* dpy, RROutput rrOutput, DisplayKHR* pDisplay, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetRandROutputDisplayEXT( m_physicalDevice, dpy, rrOutput, reinterpret_cast<VkDisplayKHR*>( pDisplay ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DisplayKHR>::type PhysicalDevice::getRandROutputDisplayEXT( Display & dpy, RROutput rrOutput, Dispatch const &d ) const\r
+ {\r
+ DisplayKHR display;\r
+ Result result = static_cast<Result>( d.vkGetRandROutputDisplayEXT( m_physicalDevice, &dpy, rrOutput, reinterpret_cast<VkDisplayKHR*>( &display ) ) );\r
+ return createResultValue( result, display, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getRandROutputDisplayEXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfaceCapabilities2EXT( SurfaceKHR surface, SurfaceCapabilities2EXT* pSurfaceCapabilities, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilities2EXT( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<VkSurfaceCapabilities2EXT*>( pSurfaceCapabilities ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceCapabilities2EXT>::type PhysicalDevice::getSurfaceCapabilities2EXT( SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ SurfaceCapabilities2EXT surfaceCapabilities;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilities2EXT( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<VkSurfaceCapabilities2EXT*>( &surfaceCapabilities ) ) );\r
+ return createResultValue( result, surfaceCapabilities, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceCapabilities2EXT" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getPresentRectanglesKHR( SurfaceKHR surface, uint32_t* pRectCount, Rect2D* pRects, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDevicePresentRectanglesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), pRectCount, reinterpret_cast<VkRect2D*>( pRects ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<Rect2D,Allocator>>::type PhysicalDevice::getPresentRectanglesKHR( SurfaceKHR surface, Dispatch const &d ) const\r
+ {\r
+ std::vector<Rect2D,Allocator> rects;\r
+ uint32_t rectCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPhysicalDevicePresentRectanglesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), &rectCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && rectCount )\r
+ {\r
+ rects.resize( rectCount );\r
+ result = static_cast<Result>( d.vkGetPhysicalDevicePresentRectanglesKHR( m_physicalDevice, static_cast<VkSurfaceKHR>( surface ), &rectCount, reinterpret_cast<VkRect2D*>( rects.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( rectCount <= rects.size() );\r
+ rects.resize( rectCount );\r
+ return createResultValue( result, rects, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getPresentRectanglesKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void PhysicalDevice::getMultisamplePropertiesEXT( SampleCountFlagBits samples, MultisamplePropertiesEXT* pMultisampleProperties, Dispatch const &d) const\r
+ {\r
+ d.vkGetPhysicalDeviceMultisamplePropertiesEXT( m_physicalDevice, static_cast<VkSampleCountFlagBits>( samples ), reinterpret_cast<VkMultisamplePropertiesEXT*>( pMultisampleProperties ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE MultisamplePropertiesEXT PhysicalDevice::getMultisamplePropertiesEXT( SampleCountFlagBits samples, Dispatch const &d ) const\r
+ {\r
+ MultisamplePropertiesEXT multisampleProperties;\r
+ d.vkGetPhysicalDeviceMultisamplePropertiesEXT( m_physicalDevice, static_cast<VkSampleCountFlagBits>( samples ), reinterpret_cast<VkMultisamplePropertiesEXT*>( &multisampleProperties ) );\r
+ return multisampleProperties;\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfaceCapabilities2KHR( const PhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, SurfaceCapabilities2KHR* pSurfaceCapabilities, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilities2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>( pSurfaceInfo ), reinterpret_cast<VkSurfaceCapabilities2KHR*>( pSurfaceCapabilities ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceCapabilities2KHR>::type PhysicalDevice::getSurfaceCapabilities2KHR( const PhysicalDeviceSurfaceInfo2KHR & surfaceInfo, Dispatch const &d ) const\r
+ {\r
+ SurfaceCapabilities2KHR surfaceCapabilities;\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilities2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>( &surfaceInfo ), reinterpret_cast<VkSurfaceCapabilities2KHR*>( &surfaceCapabilities ) ) );\r
+ return createResultValue( result, surfaceCapabilities, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceCapabilities2KHR" );\r
+ }\r
+ template <typename ...T, typename Dispatch>\r
+ VULKAN_HPP_INLINE typename ResultValueType<StructureChain<T...>>::type PhysicalDevice::getSurfaceCapabilities2KHR( const PhysicalDeviceSurfaceInfo2KHR & surfaceInfo, Dispatch const &d ) const\r
+ {\r
+ StructureChain<T...> structureChain;\r
+ SurfaceCapabilities2KHR& surfaceCapabilities = structureChain.template get<SurfaceCapabilities2KHR>();\r
+ Result result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceCapabilities2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>( &surfaceInfo ), reinterpret_cast<VkSurfaceCapabilities2KHR*>( &surfaceCapabilities ) ) );\r
+ return createResultValue( result, structureChain, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceCapabilities2KHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result PhysicalDevice::getSurfaceFormats2KHR( const PhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, uint32_t* pSurfaceFormatCount, SurfaceFormat2KHR* pSurfaceFormats, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkGetPhysicalDeviceSurfaceFormats2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>( pSurfaceInfo ), pSurfaceFormatCount, reinterpret_cast<VkSurfaceFormat2KHR*>( pSurfaceFormats ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<SurfaceFormat2KHR,Allocator>>::type PhysicalDevice::getSurfaceFormats2KHR( const PhysicalDeviceSurfaceInfo2KHR & surfaceInfo, Dispatch const &d ) const\r
+ {\r
+ std::vector<SurfaceFormat2KHR,Allocator> surfaceFormats;\r
+ uint32_t surfaceFormatCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceFormats2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>( &surfaceInfo ), &surfaceFormatCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && surfaceFormatCount )\r
+ {\r
+ surfaceFormats.resize( surfaceFormatCount );\r
+ result = static_cast<Result>( d.vkGetPhysicalDeviceSurfaceFormats2KHR( m_physicalDevice, reinterpret_cast<const VkPhysicalDeviceSurfaceInfo2KHR*>( &surfaceInfo ), &surfaceFormatCount, reinterpret_cast<VkSurfaceFormat2KHR*>( surfaceFormats.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( surfaceFormatCount <= surfaceFormats.size() );\r
+ surfaceFormats.resize( surfaceFormatCount );\r
+ return createResultValue( result, surfaceFormats, VULKAN_HPP_NAMESPACE_STRING"::PhysicalDevice::getSurfaceFormats2KHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ struct CmdProcessCommandsInfoNVX\r
+ {\r
+ CmdProcessCommandsInfoNVX( ObjectTableNVX objectTable_ = ObjectTableNVX(), IndirectCommandsLayoutNVX indirectCommandsLayout_ = IndirectCommandsLayoutNVX(), uint32_t indirectCommandsTokenCount_ = 0, const IndirectCommandsTokenNVX* pIndirectCommandsTokens_ = nullptr, uint32_t maxSequencesCount_ = 0, CommandBuffer targetCommandBuffer_ = CommandBuffer(), Buffer sequencesCountBuffer_ = Buffer(), DeviceSize sequencesCountOffset_ = 0, Buffer sequencesIndexBuffer_ = Buffer(), DeviceSize sequencesIndexOffset_ = 0 )\r
+ : objectTable( objectTable_ )\r
+ , indirectCommandsLayout( indirectCommandsLayout_ )\r
+ , indirectCommandsTokenCount( indirectCommandsTokenCount_ )\r
+ , pIndirectCommandsTokens( pIndirectCommandsTokens_ )\r
+ , maxSequencesCount( maxSequencesCount_ )\r
+ , targetCommandBuffer( targetCommandBuffer_ )\r
+ , sequencesCountBuffer( sequencesCountBuffer_ )\r
+ , sequencesCountOffset( sequencesCountOffset_ )\r
+ , sequencesIndexBuffer( sequencesIndexBuffer_ )\r
+ , sequencesIndexOffset( sequencesIndexOffset_ )\r
+ {\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX( VkCmdProcessCommandsInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CmdProcessCommandsInfoNVX ) );\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& operator=( VkCmdProcessCommandsInfoNVX const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( CmdProcessCommandsInfoNVX ) );\r
+ return *this;\r
+ }\r
+ CmdProcessCommandsInfoNVX& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setObjectTable( ObjectTableNVX objectTable_ )\r
+ {\r
+ objectTable = objectTable_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setIndirectCommandsLayout( IndirectCommandsLayoutNVX indirectCommandsLayout_ )\r
+ {\r
+ indirectCommandsLayout = indirectCommandsLayout_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setIndirectCommandsTokenCount( uint32_t indirectCommandsTokenCount_ )\r
+ {\r
+ indirectCommandsTokenCount = indirectCommandsTokenCount_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setPIndirectCommandsTokens( const IndirectCommandsTokenNVX* pIndirectCommandsTokens_ )\r
+ {\r
+ pIndirectCommandsTokens = pIndirectCommandsTokens_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setMaxSequencesCount( uint32_t maxSequencesCount_ )\r
+ {\r
+ maxSequencesCount = maxSequencesCount_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setTargetCommandBuffer( CommandBuffer targetCommandBuffer_ )\r
+ {\r
+ targetCommandBuffer = targetCommandBuffer_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setSequencesCountBuffer( Buffer sequencesCountBuffer_ )\r
+ {\r
+ sequencesCountBuffer = sequencesCountBuffer_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setSequencesCountOffset( DeviceSize sequencesCountOffset_ )\r
+ {\r
+ sequencesCountOffset = sequencesCountOffset_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setSequencesIndexBuffer( Buffer sequencesIndexBuffer_ )\r
+ {\r
+ sequencesIndexBuffer = sequencesIndexBuffer_;\r
+ return *this;\r
+ }\r
+\r
+ CmdProcessCommandsInfoNVX& setSequencesIndexOffset( DeviceSize sequencesIndexOffset_ )\r
+ {\r
+ sequencesIndexOffset = sequencesIndexOffset_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkCmdProcessCommandsInfoNVX&() const\r
+ {\r
+ return *reinterpret_cast<const VkCmdProcessCommandsInfoNVX*>(this);\r
+ }\r
+\r
+ bool operator==( CmdProcessCommandsInfoNVX const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( objectTable == rhs.objectTable )\r
+ && ( indirectCommandsLayout == rhs.indirectCommandsLayout )\r
+ && ( indirectCommandsTokenCount == rhs.indirectCommandsTokenCount )\r
+ && ( pIndirectCommandsTokens == rhs.pIndirectCommandsTokens )\r
+ && ( maxSequencesCount == rhs.maxSequencesCount )\r
+ && ( targetCommandBuffer == rhs.targetCommandBuffer )\r
+ && ( sequencesCountBuffer == rhs.sequencesCountBuffer )\r
+ && ( sequencesCountOffset == rhs.sequencesCountOffset )\r
+ && ( sequencesIndexBuffer == rhs.sequencesIndexBuffer )\r
+ && ( sequencesIndexOffset == rhs.sequencesIndexOffset );\r
+ }\r
+\r
+ bool operator!=( CmdProcessCommandsInfoNVX const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eCmdProcessCommandsInfoNVX;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ ObjectTableNVX objectTable;\r
+ IndirectCommandsLayoutNVX indirectCommandsLayout;\r
+ uint32_t indirectCommandsTokenCount;\r
+ const IndirectCommandsTokenNVX* pIndirectCommandsTokens;\r
+ uint32_t maxSequencesCount;\r
+ CommandBuffer targetCommandBuffer;\r
+ Buffer sequencesCountBuffer;\r
+ DeviceSize sequencesCountOffset;\r
+ Buffer sequencesIndexBuffer;\r
+ DeviceSize sequencesIndexOffset;\r
+ };\r
+ static_assert( sizeof( CmdProcessCommandsInfoNVX ) == sizeof( VkCmdProcessCommandsInfoNVX ), "struct and wrapper have different size!" );\r
+\r
+ struct PhysicalDeviceGroupProperties\r
+ {\r
+ operator const VkPhysicalDeviceGroupProperties&() const\r
+ {\r
+ return *reinterpret_cast<const VkPhysicalDeviceGroupProperties*>(this);\r
+ }\r
+\r
+ bool operator==( PhysicalDeviceGroupProperties const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( physicalDeviceCount == rhs.physicalDeviceCount )\r
+ && ( memcmp( physicalDevices, rhs.physicalDevices, VK_MAX_DEVICE_GROUP_SIZE * sizeof( PhysicalDevice ) ) == 0 )\r
+ && ( subsetAllocation == rhs.subsetAllocation );\r
+ }\r
+\r
+ bool operator!=( PhysicalDeviceGroupProperties const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::ePhysicalDeviceGroupProperties;\r
+\r
+ public:\r
+ void* pNext = nullptr;\r
+ uint32_t physicalDeviceCount;\r
+ PhysicalDevice physicalDevices[VK_MAX_DEVICE_GROUP_SIZE];\r
+ Bool32 subsetAllocation;\r
+ };\r
+ static_assert( sizeof( PhysicalDeviceGroupProperties ) == sizeof( VkPhysicalDeviceGroupProperties ), "struct and wrapper have different size!" );\r
+\r
+ using PhysicalDeviceGroupPropertiesKHR = PhysicalDeviceGroupProperties;\r
+\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ class Instance;\r
+\r
+ template <> class UniqueHandleTraits<DebugReportCallbackEXT> {public: using deleter = ObjectDestroy<Instance>; };\r
+ using UniqueDebugReportCallbackEXT = UniqueHandle<DebugReportCallbackEXT>;\r
+ template <> class UniqueHandleTraits<DebugUtilsMessengerEXT> {public: using deleter = ObjectDestroy<Instance>; };\r
+ using UniqueDebugUtilsMessengerEXT = UniqueHandle<DebugUtilsMessengerEXT>;\r
+ template <> class UniqueHandleTraits<SurfaceKHR> {public: using deleter = ObjectDestroy<Instance>; };\r
+ using UniqueSurfaceKHR = UniqueHandle<SurfaceKHR>;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+\r
+ class Instance\r
+ {\r
+ public:\r
+ VULKAN_HPP_CONSTEXPR Instance()\r
+ : m_instance(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_CONSTEXPR Instance( std::nullptr_t )\r
+ : m_instance(VK_NULL_HANDLE)\r
+ {}\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT Instance( VkInstance instance )\r
+ : m_instance( instance )\r
+ {}\r
+\r
+#if defined(VULKAN_HPP_TYPESAFE_CONVERSION)\r
+ Instance & operator=(VkInstance instance)\r
+ {\r
+ m_instance = instance;\r
+ return *this; \r
+ }\r
+#endif\r
+\r
+ Instance & operator=( std::nullptr_t )\r
+ {\r
+ m_instance = VK_NULL_HANDLE;\r
+ return *this;\r
+ }\r
+\r
+ bool operator==( Instance const & rhs ) const\r
+ {\r
+ return m_instance == rhs.m_instance;\r
+ }\r
+\r
+ bool operator!=(Instance const & rhs ) const\r
+ {\r
+ return m_instance != rhs.m_instance;\r
+ }\r
+\r
+ bool operator<(Instance const & rhs ) const\r
+ {\r
+ return m_instance < rhs.m_instance;\r
+ }\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumeratePhysicalDevices( uint32_t* pPhysicalDeviceCount, PhysicalDevice* pPhysicalDevices, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<PhysicalDevice>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<PhysicalDevice,Allocator>>::type enumeratePhysicalDevices(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PFN_vkVoidFunction getProcAddr( const char* pName, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ PFN_vkVoidFunction getProcAddr( const std::string & name, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createAndroidSurfaceKHR( const AndroidSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createAndroidSurfaceKHR( const AndroidSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createAndroidSurfaceKHRUnique( const AndroidSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDisplayPlaneSurfaceKHR( const DisplaySurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createDisplayPlaneSurfaceKHR( const DisplaySurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createDisplayPlaneSurfaceKHRUnique( const DisplaySurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createMirSurfaceKHR( const MirSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createMirSurfaceKHR( const MirSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createMirSurfaceKHRUnique( const MirSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySurfaceKHR( SurfaceKHR surface, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroySurfaceKHR( SurfaceKHR surface, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( SurfaceKHR surface, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( SurfaceKHR surface, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createViSurfaceNN( const ViSurfaceCreateInfoNN* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createViSurfaceNN( const ViSurfaceCreateInfoNN & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createViSurfaceNNUnique( const ViSurfaceCreateInfoNN & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createWaylandSurfaceKHR( const WaylandSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createWaylandSurfaceKHR( const WaylandSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createWaylandSurfaceKHRUnique( const WaylandSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createWin32SurfaceKHR( const Win32SurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createWin32SurfaceKHR( const Win32SurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createWin32SurfaceKHRUnique( const Win32SurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createXlibSurfaceKHR( const XlibSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createXlibSurfaceKHR( const XlibSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createXlibSurfaceKHRUnique( const XlibSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createXcbSurfaceKHR( const XcbSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createXcbSurfaceKHR( const XcbSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createXcbSurfaceKHRUnique( const XcbSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDebugReportCallbackEXT( const DebugReportCallbackCreateInfoEXT* pCreateInfo, const AllocationCallbacks* pAllocator, DebugReportCallbackEXT* pCallback, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DebugReportCallbackEXT>::type createDebugReportCallbackEXT( const DebugReportCallbackCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDebugReportCallbackEXT>::type createDebugReportCallbackEXTUnique( const DebugReportCallbackCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDebugReportCallbackEXT( DebugReportCallbackEXT callback, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDebugReportCallbackEXT( DebugReportCallbackEXT callback, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DebugReportCallbackEXT callback, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DebugReportCallbackEXT callback, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugReportMessageEXT( DebugReportFlagsEXT flags, DebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const char* pLayerPrefix, const char* pMessage, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void debugReportMessageEXT( DebugReportFlagsEXT flags, DebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const std::string & layerPrefix, const std::string & message, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumeratePhysicalDeviceGroups( uint32_t* pPhysicalDeviceGroupCount, PhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<PhysicalDeviceGroupProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<PhysicalDeviceGroupProperties,Allocator>>::type enumeratePhysicalDeviceGroups(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result enumeratePhysicalDeviceGroupsKHR( uint32_t* pPhysicalDeviceGroupCount, PhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator = std::allocator<PhysicalDeviceGroupProperties>, typename Dispatch = DispatchLoaderStatic> \r
+ typename ResultValueType<std::vector<PhysicalDeviceGroupProperties,Allocator>>::type enumeratePhysicalDeviceGroupsKHR(Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createIOSSurfaceMVK( const IOSSurfaceCreateInfoMVK* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createIOSSurfaceMVK( const IOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createIOSSurfaceMVKUnique( const IOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createMacOSSurfaceMVK( const MacOSSurfaceCreateInfoMVK* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<SurfaceKHR>::type createMacOSSurfaceMVK( const MacOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueSurfaceKHR>::type createMacOSSurfaceMVKUnique( const MacOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createDebugUtilsMessengerEXT( const DebugUtilsMessengerCreateInfoEXT* pCreateInfo, const AllocationCallbacks* pAllocator, DebugUtilsMessengerEXT* pMessenger, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<DebugUtilsMessengerEXT>::type createDebugUtilsMessengerEXT( const DebugUtilsMessengerCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueDebugUtilsMessengerEXT>::type createDebugUtilsMessengerEXTUnique( const DebugUtilsMessengerCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDebugUtilsMessengerEXT( DebugUtilsMessengerEXT messenger, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroyDebugUtilsMessengerEXT( DebugUtilsMessengerEXT messenger, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DebugUtilsMessengerEXT messenger, const AllocationCallbacks* pAllocator, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void destroy( DebugUtilsMessengerEXT messenger, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void submitDebugUtilsMessageEXT( DebugUtilsMessageSeverityFlagBitsEXT messageSeverity, DebugUtilsMessageTypeFlagsEXT messageTypes, const DebugUtilsMessengerCallbackDataEXT* pCallbackData, Dispatch const &d = Dispatch() ) const;\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ void submitDebugUtilsMessageEXT( DebugUtilsMessageSeverityFlagBitsEXT messageSeverity, DebugUtilsMessageTypeFlagsEXT messageTypes, const DebugUtilsMessengerCallbackDataEXT & callbackData, Dispatch const &d = Dispatch() ) const;\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+\r
+ VULKAN_HPP_TYPESAFE_EXPLICIT operator VkInstance() const\r
+ {\r
+ return m_instance;\r
+ }\r
+\r
+ explicit operator bool() const\r
+ {\r
+ return m_instance != VK_NULL_HANDLE;\r
+ }\r
+\r
+ bool operator!() const\r
+ {\r
+ return m_instance == VK_NULL_HANDLE;\r
+ }\r
+\r
+ private:\r
+ VkInstance m_instance;\r
+ };\r
+\r
+ static_assert( sizeof( Instance ) == sizeof( VkInstance ), "handle and wrapper have different size!" );\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyInstance( m_instance, reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyInstance( m_instance, reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::enumeratePhysicalDevices( uint32_t* pPhysicalDeviceCount, PhysicalDevice* pPhysicalDevices, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkEnumeratePhysicalDevices( m_instance, pPhysicalDeviceCount, reinterpret_cast<VkPhysicalDevice*>( pPhysicalDevices ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<PhysicalDevice,Allocator>>::type Instance::enumeratePhysicalDevices(Dispatch const &d ) const\r
+ {\r
+ std::vector<PhysicalDevice,Allocator> physicalDevices;\r
+ uint32_t physicalDeviceCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumeratePhysicalDevices( m_instance, &physicalDeviceCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && physicalDeviceCount )\r
+ {\r
+ physicalDevices.resize( physicalDeviceCount );\r
+ result = static_cast<Result>( d.vkEnumeratePhysicalDevices( m_instance, &physicalDeviceCount, reinterpret_cast<VkPhysicalDevice*>( physicalDevices.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( physicalDeviceCount <= physicalDevices.size() );\r
+ physicalDevices.resize( physicalDeviceCount );\r
+ return createResultValue( result, physicalDevices, VULKAN_HPP_NAMESPACE_STRING"::Instance::enumeratePhysicalDevices" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PFN_vkVoidFunction Instance::getProcAddr( const char* pName, Dispatch const &d) const\r
+ {\r
+ return d.vkGetInstanceProcAddr( m_instance, pName );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE PFN_vkVoidFunction Instance::getProcAddr( const std::string & name, Dispatch const &d ) const\r
+ {\r
+ return d.vkGetInstanceProcAddr( m_instance, name.c_str() );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createAndroidSurfaceKHR( const AndroidSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateAndroidSurfaceKHR( m_instance, reinterpret_cast<const VkAndroidSurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createAndroidSurfaceKHR( const AndroidSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateAndroidSurfaceKHR( m_instance, reinterpret_cast<const VkAndroidSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createAndroidSurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createAndroidSurfaceKHRUnique( const AndroidSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateAndroidSurfaceKHR( m_instance, reinterpret_cast<const VkAndroidSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createAndroidSurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createDisplayPlaneSurfaceKHR( const DisplaySurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDisplayPlaneSurfaceKHR( m_instance, reinterpret_cast<const VkDisplaySurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createDisplayPlaneSurfaceKHR( const DisplaySurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateDisplayPlaneSurfaceKHR( m_instance, reinterpret_cast<const VkDisplaySurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createDisplayPlaneSurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createDisplayPlaneSurfaceKHRUnique( const DisplaySurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateDisplayPlaneSurfaceKHR( m_instance, reinterpret_cast<const VkDisplaySurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createDisplayPlaneSurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createMirSurfaceKHR( const MirSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateMirSurfaceKHR( m_instance, reinterpret_cast<const VkMirSurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createMirSurfaceKHR( const MirSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateMirSurfaceKHR( m_instance, reinterpret_cast<const VkMirSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createMirSurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createMirSurfaceKHRUnique( const MirSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateMirSurfaceKHR( m_instance, reinterpret_cast<const VkMirSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createMirSurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroySurfaceKHR( SurfaceKHR surface, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySurfaceKHR( m_instance, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroySurfaceKHR( SurfaceKHR surface, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySurfaceKHR( m_instance, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( SurfaceKHR surface, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroySurfaceKHR( m_instance, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( SurfaceKHR surface, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroySurfaceKHR( m_instance, static_cast<VkSurfaceKHR>( surface ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createViSurfaceNN( const ViSurfaceCreateInfoNN* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateViSurfaceNN( m_instance, reinterpret_cast<const VkViSurfaceCreateInfoNN*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createViSurfaceNN( const ViSurfaceCreateInfoNN & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateViSurfaceNN( m_instance, reinterpret_cast<const VkViSurfaceCreateInfoNN*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createViSurfaceNN" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createViSurfaceNNUnique( const ViSurfaceCreateInfoNN & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateViSurfaceNN( m_instance, reinterpret_cast<const VkViSurfaceCreateInfoNN*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createViSurfaceNNUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createWaylandSurfaceKHR( const WaylandSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateWaylandSurfaceKHR( m_instance, reinterpret_cast<const VkWaylandSurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createWaylandSurfaceKHR( const WaylandSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateWaylandSurfaceKHR( m_instance, reinterpret_cast<const VkWaylandSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createWaylandSurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createWaylandSurfaceKHRUnique( const WaylandSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateWaylandSurfaceKHR( m_instance, reinterpret_cast<const VkWaylandSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createWaylandSurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createWin32SurfaceKHR( const Win32SurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateWin32SurfaceKHR( m_instance, reinterpret_cast<const VkWin32SurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createWin32SurfaceKHR( const Win32SurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateWin32SurfaceKHR( m_instance, reinterpret_cast<const VkWin32SurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createWin32SurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createWin32SurfaceKHRUnique( const Win32SurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateWin32SurfaceKHR( m_instance, reinterpret_cast<const VkWin32SurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createWin32SurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createXlibSurfaceKHR( const XlibSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateXlibSurfaceKHR( m_instance, reinterpret_cast<const VkXlibSurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createXlibSurfaceKHR( const XlibSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateXlibSurfaceKHR( m_instance, reinterpret_cast<const VkXlibSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createXlibSurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createXlibSurfaceKHRUnique( const XlibSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateXlibSurfaceKHR( m_instance, reinterpret_cast<const VkXlibSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createXlibSurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createXcbSurfaceKHR( const XcbSurfaceCreateInfoKHR* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateXcbSurfaceKHR( m_instance, reinterpret_cast<const VkXcbSurfaceCreateInfoKHR*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createXcbSurfaceKHR( const XcbSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateXcbSurfaceKHR( m_instance, reinterpret_cast<const VkXcbSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createXcbSurfaceKHR" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createXcbSurfaceKHRUnique( const XcbSurfaceCreateInfoKHR & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateXcbSurfaceKHR( m_instance, reinterpret_cast<const VkXcbSurfaceCreateInfoKHR*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createXcbSurfaceKHRUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createDebugReportCallbackEXT( const DebugReportCallbackCreateInfoEXT* pCreateInfo, const AllocationCallbacks* pAllocator, DebugReportCallbackEXT* pCallback, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDebugReportCallbackEXT( m_instance, reinterpret_cast<const VkDebugReportCallbackCreateInfoEXT*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDebugReportCallbackEXT*>( pCallback ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DebugReportCallbackEXT>::type Instance::createDebugReportCallbackEXT( const DebugReportCallbackCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DebugReportCallbackEXT callback;\r
+ Result result = static_cast<Result>( d.vkCreateDebugReportCallbackEXT( m_instance, reinterpret_cast<const VkDebugReportCallbackCreateInfoEXT*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDebugReportCallbackEXT*>( &callback ) ) );\r
+ return createResultValue( result, callback, VULKAN_HPP_NAMESPACE_STRING"::Instance::createDebugReportCallbackEXT" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDebugReportCallbackEXT>::type Instance::createDebugReportCallbackEXTUnique( const DebugReportCallbackCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DebugReportCallbackEXT callback;\r
+ Result result = static_cast<Result>( d.vkCreateDebugReportCallbackEXT( m_instance, reinterpret_cast<const VkDebugReportCallbackCreateInfoEXT*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDebugReportCallbackEXT*>( &callback ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, callback, VULKAN_HPP_NAMESPACE_STRING"::Instance::createDebugReportCallbackEXTUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroyDebugReportCallbackEXT( DebugReportCallbackEXT callback, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDebugReportCallbackEXT( m_instance, static_cast<VkDebugReportCallbackEXT>( callback ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroyDebugReportCallbackEXT( DebugReportCallbackEXT callback, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDebugReportCallbackEXT( m_instance, static_cast<VkDebugReportCallbackEXT>( callback ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( DebugReportCallbackEXT callback, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDebugReportCallbackEXT( m_instance, static_cast<VkDebugReportCallbackEXT>( callback ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( DebugReportCallbackEXT callback, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDebugReportCallbackEXT( m_instance, static_cast<VkDebugReportCallbackEXT>( callback ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::debugReportMessageEXT( DebugReportFlagsEXT flags, DebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const char* pLayerPrefix, const char* pMessage, Dispatch const &d) const\r
+ {\r
+ d.vkDebugReportMessageEXT( m_instance, static_cast<VkDebugReportFlagsEXT>( flags ), static_cast<VkDebugReportObjectTypeEXT>( objectType ), object, location, messageCode, pLayerPrefix, pMessage );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::debugReportMessageEXT( DebugReportFlagsEXT flags, DebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const std::string & layerPrefix, const std::string & message, Dispatch const &d ) const\r
+ {\r
+#ifdef VULKAN_HPP_NO_EXCEPTIONS\r
+ VULKAN_HPP_ASSERT( layerPrefix.size() == message.size() );\r
+#else\r
+ if ( layerPrefix.size() != message.size() )\r
+ {\r
+ throw LogicError( VULKAN_HPP_NAMESPACE_STRING "::Instance::debugReportMessageEXT: layerPrefix.size() != message.size()" );\r
+ }\r
+#endif // VULKAN_HPP_NO_EXCEPTIONS\r
+ d.vkDebugReportMessageEXT( m_instance, static_cast<VkDebugReportFlagsEXT>( flags ), static_cast<VkDebugReportObjectTypeEXT>( objectType ), object, location, messageCode, layerPrefix.c_str(), message.c_str() );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::enumeratePhysicalDeviceGroups( uint32_t* pPhysicalDeviceGroupCount, PhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkEnumeratePhysicalDeviceGroups( m_instance, pPhysicalDeviceGroupCount, reinterpret_cast<VkPhysicalDeviceGroupProperties*>( pPhysicalDeviceGroupProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<PhysicalDeviceGroupProperties,Allocator>>::type Instance::enumeratePhysicalDeviceGroups(Dispatch const &d ) const\r
+ {\r
+ std::vector<PhysicalDeviceGroupProperties,Allocator> physicalDeviceGroupProperties;\r
+ uint32_t physicalDeviceGroupCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumeratePhysicalDeviceGroups( m_instance, &physicalDeviceGroupCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && physicalDeviceGroupCount )\r
+ {\r
+ physicalDeviceGroupProperties.resize( physicalDeviceGroupCount );\r
+ result = static_cast<Result>( d.vkEnumeratePhysicalDeviceGroups( m_instance, &physicalDeviceGroupCount, reinterpret_cast<VkPhysicalDeviceGroupProperties*>( physicalDeviceGroupProperties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( physicalDeviceGroupCount <= physicalDeviceGroupProperties.size() );\r
+ physicalDeviceGroupProperties.resize( physicalDeviceGroupCount );\r
+ return createResultValue( result, physicalDeviceGroupProperties, VULKAN_HPP_NAMESPACE_STRING"::Instance::enumeratePhysicalDeviceGroups" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::enumeratePhysicalDeviceGroupsKHR( uint32_t* pPhysicalDeviceGroupCount, PhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkEnumeratePhysicalDeviceGroupsKHR( m_instance, pPhysicalDeviceGroupCount, reinterpret_cast<VkPhysicalDeviceGroupProperties*>( pPhysicalDeviceGroupProperties ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template <typename Allocator, typename Dispatch> \r
+ VULKAN_HPP_INLINE typename ResultValueType<std::vector<PhysicalDeviceGroupProperties,Allocator>>::type Instance::enumeratePhysicalDeviceGroupsKHR(Dispatch const &d ) const\r
+ {\r
+ std::vector<PhysicalDeviceGroupProperties,Allocator> physicalDeviceGroupProperties;\r
+ uint32_t physicalDeviceGroupCount;\r
+ Result result;\r
+ do\r
+ {\r
+ result = static_cast<Result>( d.vkEnumeratePhysicalDeviceGroupsKHR( m_instance, &physicalDeviceGroupCount, nullptr ) );\r
+ if ( ( result == Result::eSuccess ) && physicalDeviceGroupCount )\r
+ {\r
+ physicalDeviceGroupProperties.resize( physicalDeviceGroupCount );\r
+ result = static_cast<Result>( d.vkEnumeratePhysicalDeviceGroupsKHR( m_instance, &physicalDeviceGroupCount, reinterpret_cast<VkPhysicalDeviceGroupProperties*>( physicalDeviceGroupProperties.data() ) ) );\r
+ }\r
+ } while ( result == Result::eIncomplete );\r
+ VULKAN_HPP_ASSERT( physicalDeviceGroupCount <= physicalDeviceGroupProperties.size() );\r
+ physicalDeviceGroupProperties.resize( physicalDeviceGroupCount );\r
+ return createResultValue( result, physicalDeviceGroupProperties, VULKAN_HPP_NAMESPACE_STRING"::Instance::enumeratePhysicalDeviceGroupsKHR" );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createIOSSurfaceMVK( const IOSSurfaceCreateInfoMVK* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateIOSSurfaceMVK( m_instance, reinterpret_cast<const VkIOSSurfaceCreateInfoMVK*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createIOSSurfaceMVK( const IOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateIOSSurfaceMVK( m_instance, reinterpret_cast<const VkIOSSurfaceCreateInfoMVK*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createIOSSurfaceMVK" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createIOSSurfaceMVKUnique( const IOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateIOSSurfaceMVK( m_instance, reinterpret_cast<const VkIOSSurfaceCreateInfoMVK*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createIOSSurfaceMVKUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createMacOSSurfaceMVK( const MacOSSurfaceCreateInfoMVK* pCreateInfo, const AllocationCallbacks* pAllocator, SurfaceKHR* pSurface, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateMacOSSurfaceMVK( m_instance, reinterpret_cast<const VkMacOSSurfaceCreateInfoMVK*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkSurfaceKHR*>( pSurface ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<SurfaceKHR>::type Instance::createMacOSSurfaceMVK( const MacOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateMacOSSurfaceMVK( m_instance, reinterpret_cast<const VkMacOSSurfaceCreateInfoMVK*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createMacOSSurfaceMVK" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueSurfaceKHR>::type Instance::createMacOSSurfaceMVKUnique( const MacOSSurfaceCreateInfoMVK & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ SurfaceKHR surface;\r
+ Result result = static_cast<Result>( d.vkCreateMacOSSurfaceMVK( m_instance, reinterpret_cast<const VkMacOSSurfaceCreateInfoMVK*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkSurfaceKHR*>( &surface ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, surface, VULKAN_HPP_NAMESPACE_STRING"::Instance::createMacOSSurfaceMVKUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result Instance::createDebugUtilsMessengerEXT( const DebugUtilsMessengerCreateInfoEXT* pCreateInfo, const AllocationCallbacks* pAllocator, DebugUtilsMessengerEXT* pMessenger, Dispatch const &d) const\r
+ {\r
+ return static_cast<Result>( d.vkCreateDebugUtilsMessengerEXT( m_instance, reinterpret_cast<const VkDebugUtilsMessengerCreateInfoEXT*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkDebugUtilsMessengerEXT*>( pMessenger ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<DebugUtilsMessengerEXT>::type Instance::createDebugUtilsMessengerEXT( const DebugUtilsMessengerCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DebugUtilsMessengerEXT messenger;\r
+ Result result = static_cast<Result>( d.vkCreateDebugUtilsMessengerEXT( m_instance, reinterpret_cast<const VkDebugUtilsMessengerCreateInfoEXT*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDebugUtilsMessengerEXT*>( &messenger ) ) );\r
+ return createResultValue( result, messenger, VULKAN_HPP_NAMESPACE_STRING"::Instance::createDebugUtilsMessengerEXT" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueDebugUtilsMessengerEXT>::type Instance::createDebugUtilsMessengerEXTUnique( const DebugUtilsMessengerCreateInfoEXT & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ DebugUtilsMessengerEXT messenger;\r
+ Result result = static_cast<Result>( d.vkCreateDebugUtilsMessengerEXT( m_instance, reinterpret_cast<const VkDebugUtilsMessengerCreateInfoEXT*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkDebugUtilsMessengerEXT*>( &messenger ) ) );\r
+\r
+ ObjectDestroy<Instance> deleter( *this, allocator );\r
+ return createResultValue( result, messenger, VULKAN_HPP_NAMESPACE_STRING"::Instance::createDebugUtilsMessengerEXTUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroyDebugUtilsMessengerEXT( DebugUtilsMessengerEXT messenger, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDebugUtilsMessengerEXT( m_instance, static_cast<VkDebugUtilsMessengerEXT>( messenger ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroyDebugUtilsMessengerEXT( DebugUtilsMessengerEXT messenger, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDebugUtilsMessengerEXT( m_instance, static_cast<VkDebugUtilsMessengerEXT>( messenger ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( DebugUtilsMessengerEXT messenger, const AllocationCallbacks* pAllocator, Dispatch const &d) const\r
+ {\r
+ d.vkDestroyDebugUtilsMessengerEXT( m_instance, static_cast<VkDebugUtilsMessengerEXT>( messenger ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::destroy( DebugUtilsMessengerEXT messenger, Optional<const AllocationCallbacks> allocator, Dispatch const &d ) const\r
+ {\r
+ d.vkDestroyDebugUtilsMessengerEXT( m_instance, static_cast<VkDebugUtilsMessengerEXT>( messenger ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::submitDebugUtilsMessageEXT( DebugUtilsMessageSeverityFlagBitsEXT messageSeverity, DebugUtilsMessageTypeFlagsEXT messageTypes, const DebugUtilsMessengerCallbackDataEXT* pCallbackData, Dispatch const &d) const\r
+ {\r
+ d.vkSubmitDebugUtilsMessageEXT( m_instance, static_cast<VkDebugUtilsMessageSeverityFlagBitsEXT>( messageSeverity ), static_cast<VkDebugUtilsMessageTypeFlagsEXT>( messageTypes ), reinterpret_cast<const VkDebugUtilsMessengerCallbackDataEXT*>( pCallbackData ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE void Instance::submitDebugUtilsMessageEXT( DebugUtilsMessageSeverityFlagBitsEXT messageSeverity, DebugUtilsMessageTypeFlagsEXT messageTypes, const DebugUtilsMessengerCallbackDataEXT & callbackData, Dispatch const &d ) const\r
+ {\r
+ d.vkSubmitDebugUtilsMessageEXT( m_instance, static_cast<VkDebugUtilsMessageSeverityFlagBitsEXT>( messageSeverity ), static_cast<VkDebugUtilsMessageTypeFlagsEXT>( messageTypes ), reinterpret_cast<const VkDebugUtilsMessengerCallbackDataEXT*>( &callbackData ) );\r
+ }\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ struct DeviceGroupDeviceCreateInfo\r
+ {\r
+ DeviceGroupDeviceCreateInfo( uint32_t physicalDeviceCount_ = 0, const PhysicalDevice* pPhysicalDevices_ = nullptr )\r
+ : physicalDeviceCount( physicalDeviceCount_ )\r
+ , pPhysicalDevices( pPhysicalDevices_ )\r
+ {\r
+ }\r
+\r
+ DeviceGroupDeviceCreateInfo( VkDeviceGroupDeviceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupDeviceCreateInfo ) );\r
+ }\r
+\r
+ DeviceGroupDeviceCreateInfo& operator=( VkDeviceGroupDeviceCreateInfo const & rhs )\r
+ {\r
+ memcpy( this, &rhs, sizeof( DeviceGroupDeviceCreateInfo ) );\r
+ return *this;\r
+ }\r
+ DeviceGroupDeviceCreateInfo& setPNext( const void* pNext_ )\r
+ {\r
+ pNext = pNext_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupDeviceCreateInfo& setPhysicalDeviceCount( uint32_t physicalDeviceCount_ )\r
+ {\r
+ physicalDeviceCount = physicalDeviceCount_;\r
+ return *this;\r
+ }\r
+\r
+ DeviceGroupDeviceCreateInfo& setPPhysicalDevices( const PhysicalDevice* pPhysicalDevices_ )\r
+ {\r
+ pPhysicalDevices = pPhysicalDevices_;\r
+ return *this;\r
+ }\r
+\r
+ operator const VkDeviceGroupDeviceCreateInfo&() const\r
+ {\r
+ return *reinterpret_cast<const VkDeviceGroupDeviceCreateInfo*>(this);\r
+ }\r
+\r
+ bool operator==( DeviceGroupDeviceCreateInfo const& rhs ) const\r
+ {\r
+ return ( sType == rhs.sType )\r
+ && ( pNext == rhs.pNext )\r
+ && ( physicalDeviceCount == rhs.physicalDeviceCount )\r
+ && ( pPhysicalDevices == rhs.pPhysicalDevices );\r
+ }\r
+\r
+ bool operator!=( DeviceGroupDeviceCreateInfo const& rhs ) const\r
+ {\r
+ return !operator==( rhs );\r
+ }\r
+\r
+ private:\r
+ StructureType sType = StructureType::eDeviceGroupDeviceCreateInfo;\r
+\r
+ public:\r
+ const void* pNext = nullptr;\r
+ uint32_t physicalDeviceCount;\r
+ const PhysicalDevice* pPhysicalDevices;\r
+ };\r
+ static_assert( sizeof( DeviceGroupDeviceCreateInfo ) == sizeof( VkDeviceGroupDeviceCreateInfo ), "struct and wrapper have different size!" );\r
+\r
+ using DeviceGroupDeviceCreateInfoKHR = DeviceGroupDeviceCreateInfo;\r
+\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+\r
+ template <> class UniqueHandleTraits<Instance> {public: using deleter = ObjectDestroy<NoParent>; };\r
+ using UniqueInstance = UniqueHandle<Instance>;\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ Result createInstance( const InstanceCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Instance* pInstance, Dispatch const &d = Dispatch() );\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<Instance>::type createInstance( const InstanceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() );\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch = DispatchLoaderStatic>\r
+ ResultValueType<UniqueInstance>::type createInstanceUnique( const InstanceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator = nullptr, Dispatch const &d = Dispatch() );\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE Result createInstance( const InstanceCreateInfo* pCreateInfo, const AllocationCallbacks* pAllocator, Instance* pInstance, Dispatch const &d)\r
+ {\r
+ return static_cast<Result>( d.vkCreateInstance( reinterpret_cast<const VkInstanceCreateInfo*>( pCreateInfo ), reinterpret_cast<const VkAllocationCallbacks*>( pAllocator ), reinterpret_cast<VkInstance*>( pInstance ) ) );\r
+ }\r
+#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<Instance>::type createInstance( const InstanceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d )\r
+ {\r
+ Instance instance;\r
+ Result result = static_cast<Result>( d.vkCreateInstance( reinterpret_cast<const VkInstanceCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkInstance*>( &instance ) ) );\r
+ return createResultValue( result, instance, VULKAN_HPP_NAMESPACE_STRING"::createInstance" );\r
+ }\r
+#ifndef VULKAN_HPP_NO_SMART_HANDLE\r
+ template<typename Dispatch>\r
+ VULKAN_HPP_INLINE ResultValueType<UniqueInstance>::type createInstanceUnique( const InstanceCreateInfo & createInfo, Optional<const AllocationCallbacks> allocator, Dispatch const &d )\r
+ {\r
+ Instance instance;\r
+ Result result = static_cast<Result>( d.vkCreateInstance( reinterpret_cast<const VkInstanceCreateInfo*>( &createInfo ), reinterpret_cast<const VkAllocationCallbacks*>( static_cast<const AllocationCallbacks*>( allocator ) ), reinterpret_cast<VkInstance*>( &instance ) ) );\r
+\r
+ ObjectDestroy<NoParent> deleter( allocator );\r
+ return createResultValue( result, instance, VULKAN_HPP_NAMESPACE_STRING"::createInstanceUnique", deleter );\r
+ }\r
+#endif /*VULKAN_HPP_NO_SMART_HANDLE*/\r
+#endif /*VULKAN_HPP_DISABLE_ENHANCED_MODE*/\r
+\r
+\r
+ template <> struct isStructureChainValid<PresentInfoKHR, DisplayPresentInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageCreateInfo, DedicatedAllocationImageCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BufferCreateInfo, DedicatedAllocationBufferCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, DedicatedAllocationMemoryAllocateInfoNV>{ enum { value = true }; };\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ExportMemoryWin32HandleInfoNV>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ template <> struct isStructureChainValid<SubmitInfo, Win32KeyedMutexAcquireReleaseInfoNV>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDeviceFeatures2>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDevicePushDescriptorPropertiesKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PresentInfoKHR, PresentRegionsKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceVariablePointerFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDeviceVariablePointerFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceIDProperties>{ enum { value = true }; };\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ExportMemoryWin32HandleInfoKHR>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template <> struct isStructureChainValid<SubmitInfo, Win32KeyedMutexAcquireReleaseInfoKHR>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template <> struct isStructureChainValid<SemaphoreCreateInfo, ExportSemaphoreWin32HandleInfoKHR>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template <> struct isStructureChainValid<SubmitInfo, D3D12FenceSubmitInfoKHR>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template <> struct isStructureChainValid<FenceCreateInfo, ExportFenceWin32HandleInfoKHR>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceMultiviewFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDeviceMultiviewFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceMultiviewProperties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<RenderPassCreateInfo, RenderPassMultiviewCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BindBufferMemoryInfo, BindBufferMemoryDeviceGroupInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BindImageMemoryInfo, BindImageMemoryDeviceGroupInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<RenderPassBeginInfo, DeviceGroupRenderPassBeginInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<CommandBufferBeginInfo, DeviceGroupCommandBufferBeginInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SubmitInfo, DeviceGroupSubmitInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BindSparseInfo, DeviceGroupBindSparseInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageCreateInfo, ImageSwapchainCreateInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BindImageMemoryInfo, BindImageMemorySwapchainInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PresentInfoKHR, PresentTimesInfoGOOGLE>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineViewportStateCreateInfo, PipelineViewportWScalingStateCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceDiscardRectanglePropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceMultiviewPerViewAttributesPropertiesNVX>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDevice16BitStorageFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDevice16BitStorageFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryRequirements2, MemoryDedicatedRequirements>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, MemoryDedicatedAllocateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SamplerCreateInfo, SamplerYcbcrConversionInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageViewCreateInfo, SamplerYcbcrConversionInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceSamplerYcbcrConversionFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDeviceSamplerYcbcrConversionFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageFormatProperties2, SamplerYcbcrConversionImageFormatProperties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageFormatProperties2, TextureLODGatherFormatPropertiesAMD>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SubmitInfo, ProtectedSubmitInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceProtectedMemoryFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDeviceProtectedMemoryFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceProtectedMemoryProperties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineMultisampleStateCreateInfo, PipelineCoverageToColorStateCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceSamplerFilterMinmaxPropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceBlendOperationAdvancedFeaturesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceBlendOperationAdvancedPropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageCreateInfo, ImageFormatListCreateInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ShaderModuleCreateInfo, ShaderModuleValidationCacheCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceMaintenance3Properties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceShaderDrawParameterFeatures>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceExternalMemoryHostPropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceConservativeRasterizationPropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceShaderCorePropertiesAMD>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceFeatures2, PhysicalDeviceDescriptorIndexingFeaturesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, PhysicalDeviceDescriptorIndexingFeaturesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceDescriptorIndexingPropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DescriptorSetAllocateInfo, DescriptorSetVariableDescriptorCountAllocateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DescriptorSetLayoutSupport, DescriptorSetVariableDescriptorCountLayoutSupportEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineVertexInputStateCreateInfo, PipelineVertexInputDivisorStateCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceVertexAttributeDivisorPropertiesEXT>{ enum { value = true }; };\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ImportAndroidHardwareBufferInfoANDROID>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template <> struct isStructureChainValid<ImageFormatProperties2, AndroidHardwareBufferUsageANDROID>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template <> struct isStructureChainValid<ImageCreateInfo, ExternalFormatANDROID>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SamplerYcbcrConversionCreateInfo, ExternalFormatANDROID>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ template <> struct isStructureChainValid<SurfaceCapabilities2KHR, SharedPresentSurfaceCapabilitiesKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageViewCreateInfo, ImageViewUsageCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<RenderPassCreateInfo, RenderPassInputAttachmentAspectCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BindImageMemoryInfo, BindImagePlaneMemoryInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageMemoryRequirementsInfo2, ImagePlaneMemoryRequirementsInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageMemoryBarrier, SampleLocationsInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<RenderPassBeginInfo, RenderPassSampleLocationsBeginInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineMultisampleStateCreateInfo, PipelineSampleLocationsStateCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceSampleLocationsPropertiesEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<InstanceCreateInfo, DebugReportCallbackCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineRasterizationStateCreateInfo, PipelineRasterizationStateRasterizationOrderAMD>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageCreateInfo, ExternalMemoryImageCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ExportMemoryAllocateInfoNV>{ enum { value = true }; };\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ImportMemoryWin32HandleInfoNV>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+ template <> struct isStructureChainValid<InstanceCreateInfo, ValidationFlagsEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDeviceSubgroupProperties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceImageFormatInfo2, PhysicalDeviceExternalImageFormatInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageCreateInfo, ExternalMemoryImageCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<BufferCreateInfo, ExternalMemoryBufferCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ExportMemoryAllocateInfo>{ enum { value = true }; };\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ImportMemoryWin32HandleInfoKHR>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ImportMemoryFdInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, ImportMemoryHostPointerInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<ImageFormatProperties2, ExternalImageFormatProperties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SemaphoreCreateInfo, ExportSemaphoreCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<FenceCreateInfo, ExportFenceCreateInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SwapchainCreateInfoKHR, SwapchainCounterCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<MemoryAllocateInfo, MemoryAllocateFlagsInfo>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PresentInfoKHR, DeviceGroupPresentInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SwapchainCreateInfoKHR, DeviceGroupSwapchainCreateInfoKHR>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineViewportStateCreateInfo, PipelineViewportSwizzleStateCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<GraphicsPipelineCreateInfo, PipelineDiscardRectangleStateCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PhysicalDeviceProperties2, PhysicalDevicePointClippingProperties>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<SamplerCreateInfo, SamplerReductionModeCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineTessellationStateCreateInfo, PipelineTessellationDomainOriginStateCreateInfo>{ enum { value = true }; };\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ template <> struct isStructureChainValid<AndroidHardwareBufferPropertiesANDROID, AndroidHardwareBufferFormatPropertiesANDROID>{ enum { value = true }; };\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ template <> struct isStructureChainValid<PipelineColorBlendStateCreateInfo, PipelineColorBlendAdvancedStateCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineMultisampleStateCreateInfo, PipelineCoverageModulationStateCreateInfoNV>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceQueueCreateInfo, DeviceQueueGlobalPriorityCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<InstanceCreateInfo, DebugUtilsMessengerCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<PipelineRasterizationStateCreateInfo, PipelineRasterizationConservativeStateCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DescriptorSetLayoutCreateInfo, DescriptorSetLayoutBindingFlagsCreateInfoEXT>{ enum { value = true }; };\r
+ template <> struct isStructureChainValid<DeviceCreateInfo, DeviceGroupDeviceCreateInfo>{ enum { value = true }; };\r
+ VULKAN_HPP_INLINE std::string to_string(FramebufferCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FramebufferCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryPoolCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryPoolCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(RenderPassCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(RenderPassCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineLayoutCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineLayoutCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCacheCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCacheCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineDepthStencilStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineDepthStencilStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineDynamicStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineDynamicStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineColorBlendStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineColorBlendStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineMultisampleStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineMultisampleStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineRasterizationStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineRasterizationStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineViewportStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineViewportStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineTessellationStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineTessellationStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineInputAssemblyStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineInputAssemblyStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineVertexInputStateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineVertexInputStateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineShaderStageCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineShaderStageCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BufferViewCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BufferViewCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(InstanceCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(InstanceCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageViewCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageViewCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SemaphoreCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SemaphoreCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ShaderModuleCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ShaderModuleCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(EventCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(EventCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryMapFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryMapFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorPoolResetFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorPoolResetFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorUpdateTemplateCreateFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorUpdateTemplateCreateFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplayModeCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplayModeCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplaySurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplaySurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(AndroidSurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(AndroidSurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(MirSurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(MirSurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ VULKAN_HPP_INLINE std::string to_string(ViSurfaceCreateFlagBitsNN)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ VULKAN_HPP_INLINE std::string to_string(ViSurfaceCreateFlagsNN)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(WaylandSurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(WaylandSurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(Win32SurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(Win32SurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(XlibSurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(XlibSurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(XcbSurfaceCreateFlagBitsKHR)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ VULKAN_HPP_INLINE std::string to_string(XcbSurfaceCreateFlagsKHR)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ VULKAN_HPP_INLINE std::string to_string(IOSSurfaceCreateFlagBitsMVK)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ VULKAN_HPP_INLINE std::string to_string(IOSSurfaceCreateFlagsMVK)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ VULKAN_HPP_INLINE std::string to_string(MacOSSurfaceCreateFlagBitsMVK)\r
+ {\r
+ return "(void)";\r
+ }\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ VULKAN_HPP_INLINE std::string to_string(MacOSSurfaceCreateFlagsMVK)\r
+ {\r
+ return "{}";\r
+ }\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandPoolTrimFlagBits)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandPoolTrimFlags)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineViewportSwizzleStateCreateFlagBitsNV)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineViewportSwizzleStateCreateFlagsNV)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineDiscardRectangleStateCreateFlagBitsEXT)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineDiscardRectangleStateCreateFlagsEXT)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCoverageToColorStateCreateFlagBitsNV)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCoverageToColorStateCreateFlagsNV)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCoverageModulationStateCreateFlagBitsNV)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCoverageModulationStateCreateFlagsNV)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ValidationCacheCreateFlagBitsEXT)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ValidationCacheCreateFlagsEXT)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessengerCreateFlagBitsEXT)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessengerCreateFlagsEXT)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessengerCallbackDataFlagBitsEXT)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessengerCallbackDataFlagsEXT)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineRasterizationConservativeStateCreateFlagBitsEXT)\r
+ {\r
+ return "(void)";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineRasterizationConservativeStateCreateFlagsEXT)\r
+ {\r
+ return "{}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageLayout value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageLayout::eUndefined: return "Undefined";\r
+ case ImageLayout::eGeneral: return "General";\r
+ case ImageLayout::eColorAttachmentOptimal: return "ColorAttachmentOptimal";\r
+ case ImageLayout::eDepthStencilAttachmentOptimal: return "DepthStencilAttachmentOptimal";\r
+ case ImageLayout::eDepthStencilReadOnlyOptimal: return "DepthStencilReadOnlyOptimal";\r
+ case ImageLayout::eShaderReadOnlyOptimal: return "ShaderReadOnlyOptimal";\r
+ case ImageLayout::eTransferSrcOptimal: return "TransferSrcOptimal";\r
+ case ImageLayout::eTransferDstOptimal: return "TransferDstOptimal";\r
+ case ImageLayout::ePreinitialized: return "Preinitialized";\r
+ case ImageLayout::eDepthReadOnlyStencilAttachmentOptimal: return "DepthReadOnlyStencilAttachmentOptimal";\r
+ case ImageLayout::eDepthAttachmentStencilReadOnlyOptimal: return "DepthAttachmentStencilReadOnlyOptimal";\r
+ case ImageLayout::ePresentSrcKHR: return "PresentSrcKHR";\r
+ case ImageLayout::eSharedPresentKHR: return "SharedPresentKHR";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(AttachmentLoadOp value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case AttachmentLoadOp::eLoad: return "Load";\r
+ case AttachmentLoadOp::eClear: return "Clear";\r
+ case AttachmentLoadOp::eDontCare: return "DontCare";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(AttachmentStoreOp value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case AttachmentStoreOp::eStore: return "Store";\r
+ case AttachmentStoreOp::eDontCare: return "DontCare";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageType::e1D: return "1D";\r
+ case ImageType::e2D: return "2D";\r
+ case ImageType::e3D: return "3D";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageTiling value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageTiling::eOptimal: return "Optimal";\r
+ case ImageTiling::eLinear: return "Linear";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageViewType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageViewType::e1D: return "1D";\r
+ case ImageViewType::e2D: return "2D";\r
+ case ImageViewType::e3D: return "3D";\r
+ case ImageViewType::eCube: return "Cube";\r
+ case ImageViewType::e1DArray: return "1DArray";\r
+ case ImageViewType::e2DArray: return "2DArray";\r
+ case ImageViewType::eCubeArray: return "CubeArray";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandBufferLevel value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CommandBufferLevel::ePrimary: return "Primary";\r
+ case CommandBufferLevel::eSecondary: return "Secondary";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ComponentSwizzle value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ComponentSwizzle::eIdentity: return "Identity";\r
+ case ComponentSwizzle::eZero: return "Zero";\r
+ case ComponentSwizzle::eOne: return "One";\r
+ case ComponentSwizzle::eR: return "R";\r
+ case ComponentSwizzle::eG: return "G";\r
+ case ComponentSwizzle::eB: return "B";\r
+ case ComponentSwizzle::eA: return "A";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DescriptorType::eSampler: return "Sampler";\r
+ case DescriptorType::eCombinedImageSampler: return "CombinedImageSampler";\r
+ case DescriptorType::eSampledImage: return "SampledImage";\r
+ case DescriptorType::eStorageImage: return "StorageImage";\r
+ case DescriptorType::eUniformTexelBuffer: return "UniformTexelBuffer";\r
+ case DescriptorType::eStorageTexelBuffer: return "StorageTexelBuffer";\r
+ case DescriptorType::eUniformBuffer: return "UniformBuffer";\r
+ case DescriptorType::eStorageBuffer: return "StorageBuffer";\r
+ case DescriptorType::eUniformBufferDynamic: return "UniformBufferDynamic";\r
+ case DescriptorType::eStorageBufferDynamic: return "StorageBufferDynamic";\r
+ case DescriptorType::eInputAttachment: return "InputAttachment";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case QueryType::eOcclusion: return "Occlusion";\r
+ case QueryType::ePipelineStatistics: return "PipelineStatistics";\r
+ case QueryType::eTimestamp: return "Timestamp";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BorderColor value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case BorderColor::eFloatTransparentBlack: return "FloatTransparentBlack";\r
+ case BorderColor::eIntTransparentBlack: return "IntTransparentBlack";\r
+ case BorderColor::eFloatOpaqueBlack: return "FloatOpaqueBlack";\r
+ case BorderColor::eIntOpaqueBlack: return "IntOpaqueBlack";\r
+ case BorderColor::eFloatOpaqueWhite: return "FloatOpaqueWhite";\r
+ case BorderColor::eIntOpaqueWhite: return "IntOpaqueWhite";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineBindPoint value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PipelineBindPoint::eGraphics: return "Graphics";\r
+ case PipelineBindPoint::eCompute: return "Compute";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCacheHeaderVersion value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PipelineCacheHeaderVersion::eOne: return "One";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PrimitiveTopology value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PrimitiveTopology::ePointList: return "PointList";\r
+ case PrimitiveTopology::eLineList: return "LineList";\r
+ case PrimitiveTopology::eLineStrip: return "LineStrip";\r
+ case PrimitiveTopology::eTriangleList: return "TriangleList";\r
+ case PrimitiveTopology::eTriangleStrip: return "TriangleStrip";\r
+ case PrimitiveTopology::eTriangleFan: return "TriangleFan";\r
+ case PrimitiveTopology::eLineListWithAdjacency: return "LineListWithAdjacency";\r
+ case PrimitiveTopology::eLineStripWithAdjacency: return "LineStripWithAdjacency";\r
+ case PrimitiveTopology::eTriangleListWithAdjacency: return "TriangleListWithAdjacency";\r
+ case PrimitiveTopology::eTriangleStripWithAdjacency: return "TriangleStripWithAdjacency";\r
+ case PrimitiveTopology::ePatchList: return "PatchList";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SharingMode value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SharingMode::eExclusive: return "Exclusive";\r
+ case SharingMode::eConcurrent: return "Concurrent";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(IndexType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case IndexType::eUint16: return "Uint16";\r
+ case IndexType::eUint32: return "Uint32";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(Filter value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case Filter::eNearest: return "Nearest";\r
+ case Filter::eLinear: return "Linear";\r
+ case Filter::eCubicIMG: return "CubicIMG";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerMipmapMode value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SamplerMipmapMode::eNearest: return "Nearest";\r
+ case SamplerMipmapMode::eLinear: return "Linear";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerAddressMode value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SamplerAddressMode::eRepeat: return "Repeat";\r
+ case SamplerAddressMode::eMirroredRepeat: return "MirroredRepeat";\r
+ case SamplerAddressMode::eClampToEdge: return "ClampToEdge";\r
+ case SamplerAddressMode::eClampToBorder: return "ClampToBorder";\r
+ case SamplerAddressMode::eMirrorClampToEdge: return "MirrorClampToEdge";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CompareOp value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CompareOp::eNever: return "Never";\r
+ case CompareOp::eLess: return "Less";\r
+ case CompareOp::eEqual: return "Equal";\r
+ case CompareOp::eLessOrEqual: return "LessOrEqual";\r
+ case CompareOp::eGreater: return "Greater";\r
+ case CompareOp::eNotEqual: return "NotEqual";\r
+ case CompareOp::eGreaterOrEqual: return "GreaterOrEqual";\r
+ case CompareOp::eAlways: return "Always";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PolygonMode value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PolygonMode::eFill: return "Fill";\r
+ case PolygonMode::eLine: return "Line";\r
+ case PolygonMode::ePoint: return "Point";\r
+ case PolygonMode::eFillRectangleNV: return "FillRectangleNV";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CullModeFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CullModeFlagBits::eNone: return "None";\r
+ case CullModeFlagBits::eFront: return "Front";\r
+ case CullModeFlagBits::eBack: return "Back";\r
+ case CullModeFlagBits::eFrontAndBack: return "FrontAndBack";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CullModeFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & CullModeFlagBits::eNone) result += "None | ";\r
+ if (value & CullModeFlagBits::eFront) result += "Front | ";\r
+ if (value & CullModeFlagBits::eBack) result += "Back | ";\r
+ if (value & CullModeFlagBits::eFrontAndBack) result += "FrontAndBack | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FrontFace value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case FrontFace::eCounterClockwise: return "CounterClockwise";\r
+ case FrontFace::eClockwise: return "Clockwise";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BlendFactor value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case BlendFactor::eZero: return "Zero";\r
+ case BlendFactor::eOne: return "One";\r
+ case BlendFactor::eSrcColor: return "SrcColor";\r
+ case BlendFactor::eOneMinusSrcColor: return "OneMinusSrcColor";\r
+ case BlendFactor::eDstColor: return "DstColor";\r
+ case BlendFactor::eOneMinusDstColor: return "OneMinusDstColor";\r
+ case BlendFactor::eSrcAlpha: return "SrcAlpha";\r
+ case BlendFactor::eOneMinusSrcAlpha: return "OneMinusSrcAlpha";\r
+ case BlendFactor::eDstAlpha: return "DstAlpha";\r
+ case BlendFactor::eOneMinusDstAlpha: return "OneMinusDstAlpha";\r
+ case BlendFactor::eConstantColor: return "ConstantColor";\r
+ case BlendFactor::eOneMinusConstantColor: return "OneMinusConstantColor";\r
+ case BlendFactor::eConstantAlpha: return "ConstantAlpha";\r
+ case BlendFactor::eOneMinusConstantAlpha: return "OneMinusConstantAlpha";\r
+ case BlendFactor::eSrcAlphaSaturate: return "SrcAlphaSaturate";\r
+ case BlendFactor::eSrc1Color: return "Src1Color";\r
+ case BlendFactor::eOneMinusSrc1Color: return "OneMinusSrc1Color";\r
+ case BlendFactor::eSrc1Alpha: return "Src1Alpha";\r
+ case BlendFactor::eOneMinusSrc1Alpha: return "OneMinusSrc1Alpha";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BlendOp value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case BlendOp::eAdd: return "Add";\r
+ case BlendOp::eSubtract: return "Subtract";\r
+ case BlendOp::eReverseSubtract: return "ReverseSubtract";\r
+ case BlendOp::eMin: return "Min";\r
+ case BlendOp::eMax: return "Max";\r
+ case BlendOp::eZeroEXT: return "ZeroEXT";\r
+ case BlendOp::eSrcEXT: return "SrcEXT";\r
+ case BlendOp::eDstEXT: return "DstEXT";\r
+ case BlendOp::eSrcOverEXT: return "SrcOverEXT";\r
+ case BlendOp::eDstOverEXT: return "DstOverEXT";\r
+ case BlendOp::eSrcInEXT: return "SrcInEXT";\r
+ case BlendOp::eDstInEXT: return "DstInEXT";\r
+ case BlendOp::eSrcOutEXT: return "SrcOutEXT";\r
+ case BlendOp::eDstOutEXT: return "DstOutEXT";\r
+ case BlendOp::eSrcAtopEXT: return "SrcAtopEXT";\r
+ case BlendOp::eDstAtopEXT: return "DstAtopEXT";\r
+ case BlendOp::eXorEXT: return "XorEXT";\r
+ case BlendOp::eMultiplyEXT: return "MultiplyEXT";\r
+ case BlendOp::eScreenEXT: return "ScreenEXT";\r
+ case BlendOp::eOverlayEXT: return "OverlayEXT";\r
+ case BlendOp::eDarkenEXT: return "DarkenEXT";\r
+ case BlendOp::eLightenEXT: return "LightenEXT";\r
+ case BlendOp::eColordodgeEXT: return "ColordodgeEXT";\r
+ case BlendOp::eColorburnEXT: return "ColorburnEXT";\r
+ case BlendOp::eHardlightEXT: return "HardlightEXT";\r
+ case BlendOp::eSoftlightEXT: return "SoftlightEXT";\r
+ case BlendOp::eDifferenceEXT: return "DifferenceEXT";\r
+ case BlendOp::eExclusionEXT: return "ExclusionEXT";\r
+ case BlendOp::eInvertEXT: return "InvertEXT";\r
+ case BlendOp::eInvertRgbEXT: return "InvertRgbEXT";\r
+ case BlendOp::eLineardodgeEXT: return "LineardodgeEXT";\r
+ case BlendOp::eLinearburnEXT: return "LinearburnEXT";\r
+ case BlendOp::eVividlightEXT: return "VividlightEXT";\r
+ case BlendOp::eLinearlightEXT: return "LinearlightEXT";\r
+ case BlendOp::ePinlightEXT: return "PinlightEXT";\r
+ case BlendOp::eHardmixEXT: return "HardmixEXT";\r
+ case BlendOp::eHslHueEXT: return "HslHueEXT";\r
+ case BlendOp::eHslSaturationEXT: return "HslSaturationEXT";\r
+ case BlendOp::eHslColorEXT: return "HslColorEXT";\r
+ case BlendOp::eHslLuminosityEXT: return "HslLuminosityEXT";\r
+ case BlendOp::ePlusEXT: return "PlusEXT";\r
+ case BlendOp::ePlusClampedEXT: return "PlusClampedEXT";\r
+ case BlendOp::ePlusClampedAlphaEXT: return "PlusClampedAlphaEXT";\r
+ case BlendOp::ePlusDarkerEXT: return "PlusDarkerEXT";\r
+ case BlendOp::eMinusEXT: return "MinusEXT";\r
+ case BlendOp::eMinusClampedEXT: return "MinusClampedEXT";\r
+ case BlendOp::eContrastEXT: return "ContrastEXT";\r
+ case BlendOp::eInvertOvgEXT: return "InvertOvgEXT";\r
+ case BlendOp::eRedEXT: return "RedEXT";\r
+ case BlendOp::eGreenEXT: return "GreenEXT";\r
+ case BlendOp::eBlueEXT: return "BlueEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(StencilOp value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case StencilOp::eKeep: return "Keep";\r
+ case StencilOp::eZero: return "Zero";\r
+ case StencilOp::eReplace: return "Replace";\r
+ case StencilOp::eIncrementAndClamp: return "IncrementAndClamp";\r
+ case StencilOp::eDecrementAndClamp: return "DecrementAndClamp";\r
+ case StencilOp::eInvert: return "Invert";\r
+ case StencilOp::eIncrementAndWrap: return "IncrementAndWrap";\r
+ case StencilOp::eDecrementAndWrap: return "DecrementAndWrap";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(LogicOp value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case LogicOp::eClear: return "Clear";\r
+ case LogicOp::eAnd: return "And";\r
+ case LogicOp::eAndReverse: return "AndReverse";\r
+ case LogicOp::eCopy: return "Copy";\r
+ case LogicOp::eAndInverted: return "AndInverted";\r
+ case LogicOp::eNoOp: return "NoOp";\r
+ case LogicOp::eXor: return "Xor";\r
+ case LogicOp::eOr: return "Or";\r
+ case LogicOp::eNor: return "Nor";\r
+ case LogicOp::eEquivalent: return "Equivalent";\r
+ case LogicOp::eInvert: return "Invert";\r
+ case LogicOp::eOrReverse: return "OrReverse";\r
+ case LogicOp::eCopyInverted: return "CopyInverted";\r
+ case LogicOp::eOrInverted: return "OrInverted";\r
+ case LogicOp::eNand: return "Nand";\r
+ case LogicOp::eSet: return "Set";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(InternalAllocationType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case InternalAllocationType::eExecutable: return "Executable";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SystemAllocationScope value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SystemAllocationScope::eCommand: return "Command";\r
+ case SystemAllocationScope::eObject: return "Object";\r
+ case SystemAllocationScope::eCache: return "Cache";\r
+ case SystemAllocationScope::eDevice: return "Device";\r
+ case SystemAllocationScope::eInstance: return "Instance";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PhysicalDeviceType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PhysicalDeviceType::eOther: return "Other";\r
+ case PhysicalDeviceType::eIntegratedGpu: return "IntegratedGpu";\r
+ case PhysicalDeviceType::eDiscreteGpu: return "DiscreteGpu";\r
+ case PhysicalDeviceType::eVirtualGpu: return "VirtualGpu";\r
+ case PhysicalDeviceType::eCpu: return "Cpu";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(VertexInputRate value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case VertexInputRate::eVertex: return "Vertex";\r
+ case VertexInputRate::eInstance: return "Instance";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(Format value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case Format::eUndefined: return "Undefined";\r
+ case Format::eR4G4UnormPack8: return "R4G4UnormPack8";\r
+ case Format::eR4G4B4A4UnormPack16: return "R4G4B4A4UnormPack16";\r
+ case Format::eB4G4R4A4UnormPack16: return "B4G4R4A4UnormPack16";\r
+ case Format::eR5G6B5UnormPack16: return "R5G6B5UnormPack16";\r
+ case Format::eB5G6R5UnormPack16: return "B5G6R5UnormPack16";\r
+ case Format::eR5G5B5A1UnormPack16: return "R5G5B5A1UnormPack16";\r
+ case Format::eB5G5R5A1UnormPack16: return "B5G5R5A1UnormPack16";\r
+ case Format::eA1R5G5B5UnormPack16: return "A1R5G5B5UnormPack16";\r
+ case Format::eR8Unorm: return "R8Unorm";\r
+ case Format::eR8Snorm: return "R8Snorm";\r
+ case Format::eR8Uscaled: return "R8Uscaled";\r
+ case Format::eR8Sscaled: return "R8Sscaled";\r
+ case Format::eR8Uint: return "R8Uint";\r
+ case Format::eR8Sint: return "R8Sint";\r
+ case Format::eR8Srgb: return "R8Srgb";\r
+ case Format::eR8G8Unorm: return "R8G8Unorm";\r
+ case Format::eR8G8Snorm: return "R8G8Snorm";\r
+ case Format::eR8G8Uscaled: return "R8G8Uscaled";\r
+ case Format::eR8G8Sscaled: return "R8G8Sscaled";\r
+ case Format::eR8G8Uint: return "R8G8Uint";\r
+ case Format::eR8G8Sint: return "R8G8Sint";\r
+ case Format::eR8G8Srgb: return "R8G8Srgb";\r
+ case Format::eR8G8B8Unorm: return "R8G8B8Unorm";\r
+ case Format::eR8G8B8Snorm: return "R8G8B8Snorm";\r
+ case Format::eR8G8B8Uscaled: return "R8G8B8Uscaled";\r
+ case Format::eR8G8B8Sscaled: return "R8G8B8Sscaled";\r
+ case Format::eR8G8B8Uint: return "R8G8B8Uint";\r
+ case Format::eR8G8B8Sint: return "R8G8B8Sint";\r
+ case Format::eR8G8B8Srgb: return "R8G8B8Srgb";\r
+ case Format::eB8G8R8Unorm: return "B8G8R8Unorm";\r
+ case Format::eB8G8R8Snorm: return "B8G8R8Snorm";\r
+ case Format::eB8G8R8Uscaled: return "B8G8R8Uscaled";\r
+ case Format::eB8G8R8Sscaled: return "B8G8R8Sscaled";\r
+ case Format::eB8G8R8Uint: return "B8G8R8Uint";\r
+ case Format::eB8G8R8Sint: return "B8G8R8Sint";\r
+ case Format::eB8G8R8Srgb: return "B8G8R8Srgb";\r
+ case Format::eR8G8B8A8Unorm: return "R8G8B8A8Unorm";\r
+ case Format::eR8G8B8A8Snorm: return "R8G8B8A8Snorm";\r
+ case Format::eR8G8B8A8Uscaled: return "R8G8B8A8Uscaled";\r
+ case Format::eR8G8B8A8Sscaled: return "R8G8B8A8Sscaled";\r
+ case Format::eR8G8B8A8Uint: return "R8G8B8A8Uint";\r
+ case Format::eR8G8B8A8Sint: return "R8G8B8A8Sint";\r
+ case Format::eR8G8B8A8Srgb: return "R8G8B8A8Srgb";\r
+ case Format::eB8G8R8A8Unorm: return "B8G8R8A8Unorm";\r
+ case Format::eB8G8R8A8Snorm: return "B8G8R8A8Snorm";\r
+ case Format::eB8G8R8A8Uscaled: return "B8G8R8A8Uscaled";\r
+ case Format::eB8G8R8A8Sscaled: return "B8G8R8A8Sscaled";\r
+ case Format::eB8G8R8A8Uint: return "B8G8R8A8Uint";\r
+ case Format::eB8G8R8A8Sint: return "B8G8R8A8Sint";\r
+ case Format::eB8G8R8A8Srgb: return "B8G8R8A8Srgb";\r
+ case Format::eA8B8G8R8UnormPack32: return "A8B8G8R8UnormPack32";\r
+ case Format::eA8B8G8R8SnormPack32: return "A8B8G8R8SnormPack32";\r
+ case Format::eA8B8G8R8UscaledPack32: return "A8B8G8R8UscaledPack32";\r
+ case Format::eA8B8G8R8SscaledPack32: return "A8B8G8R8SscaledPack32";\r
+ case Format::eA8B8G8R8UintPack32: return "A8B8G8R8UintPack32";\r
+ case Format::eA8B8G8R8SintPack32: return "A8B8G8R8SintPack32";\r
+ case Format::eA8B8G8R8SrgbPack32: return "A8B8G8R8SrgbPack32";\r
+ case Format::eA2R10G10B10UnormPack32: return "A2R10G10B10UnormPack32";\r
+ case Format::eA2R10G10B10SnormPack32: return "A2R10G10B10SnormPack32";\r
+ case Format::eA2R10G10B10UscaledPack32: return "A2R10G10B10UscaledPack32";\r
+ case Format::eA2R10G10B10SscaledPack32: return "A2R10G10B10SscaledPack32";\r
+ case Format::eA2R10G10B10UintPack32: return "A2R10G10B10UintPack32";\r
+ case Format::eA2R10G10B10SintPack32: return "A2R10G10B10SintPack32";\r
+ case Format::eA2B10G10R10UnormPack32: return "A2B10G10R10UnormPack32";\r
+ case Format::eA2B10G10R10SnormPack32: return "A2B10G10R10SnormPack32";\r
+ case Format::eA2B10G10R10UscaledPack32: return "A2B10G10R10UscaledPack32";\r
+ case Format::eA2B10G10R10SscaledPack32: return "A2B10G10R10SscaledPack32";\r
+ case Format::eA2B10G10R10UintPack32: return "A2B10G10R10UintPack32";\r
+ case Format::eA2B10G10R10SintPack32: return "A2B10G10R10SintPack32";\r
+ case Format::eR16Unorm: return "R16Unorm";\r
+ case Format::eR16Snorm: return "R16Snorm";\r
+ case Format::eR16Uscaled: return "R16Uscaled";\r
+ case Format::eR16Sscaled: return "R16Sscaled";\r
+ case Format::eR16Uint: return "R16Uint";\r
+ case Format::eR16Sint: return "R16Sint";\r
+ case Format::eR16Sfloat: return "R16Sfloat";\r
+ case Format::eR16G16Unorm: return "R16G16Unorm";\r
+ case Format::eR16G16Snorm: return "R16G16Snorm";\r
+ case Format::eR16G16Uscaled: return "R16G16Uscaled";\r
+ case Format::eR16G16Sscaled: return "R16G16Sscaled";\r
+ case Format::eR16G16Uint: return "R16G16Uint";\r
+ case Format::eR16G16Sint: return "R16G16Sint";\r
+ case Format::eR16G16Sfloat: return "R16G16Sfloat";\r
+ case Format::eR16G16B16Unorm: return "R16G16B16Unorm";\r
+ case Format::eR16G16B16Snorm: return "R16G16B16Snorm";\r
+ case Format::eR16G16B16Uscaled: return "R16G16B16Uscaled";\r
+ case Format::eR16G16B16Sscaled: return "R16G16B16Sscaled";\r
+ case Format::eR16G16B16Uint: return "R16G16B16Uint";\r
+ case Format::eR16G16B16Sint: return "R16G16B16Sint";\r
+ case Format::eR16G16B16Sfloat: return "R16G16B16Sfloat";\r
+ case Format::eR16G16B16A16Unorm: return "R16G16B16A16Unorm";\r
+ case Format::eR16G16B16A16Snorm: return "R16G16B16A16Snorm";\r
+ case Format::eR16G16B16A16Uscaled: return "R16G16B16A16Uscaled";\r
+ case Format::eR16G16B16A16Sscaled: return "R16G16B16A16Sscaled";\r
+ case Format::eR16G16B16A16Uint: return "R16G16B16A16Uint";\r
+ case Format::eR16G16B16A16Sint: return "R16G16B16A16Sint";\r
+ case Format::eR16G16B16A16Sfloat: return "R16G16B16A16Sfloat";\r
+ case Format::eR32Uint: return "R32Uint";\r
+ case Format::eR32Sint: return "R32Sint";\r
+ case Format::eR32Sfloat: return "R32Sfloat";\r
+ case Format::eR32G32Uint: return "R32G32Uint";\r
+ case Format::eR32G32Sint: return "R32G32Sint";\r
+ case Format::eR32G32Sfloat: return "R32G32Sfloat";\r
+ case Format::eR32G32B32Uint: return "R32G32B32Uint";\r
+ case Format::eR32G32B32Sint: return "R32G32B32Sint";\r
+ case Format::eR32G32B32Sfloat: return "R32G32B32Sfloat";\r
+ case Format::eR32G32B32A32Uint: return "R32G32B32A32Uint";\r
+ case Format::eR32G32B32A32Sint: return "R32G32B32A32Sint";\r
+ case Format::eR32G32B32A32Sfloat: return "R32G32B32A32Sfloat";\r
+ case Format::eR64Uint: return "R64Uint";\r
+ case Format::eR64Sint: return "R64Sint";\r
+ case Format::eR64Sfloat: return "R64Sfloat";\r
+ case Format::eR64G64Uint: return "R64G64Uint";\r
+ case Format::eR64G64Sint: return "R64G64Sint";\r
+ case Format::eR64G64Sfloat: return "R64G64Sfloat";\r
+ case Format::eR64G64B64Uint: return "R64G64B64Uint";\r
+ case Format::eR64G64B64Sint: return "R64G64B64Sint";\r
+ case Format::eR64G64B64Sfloat: return "R64G64B64Sfloat";\r
+ case Format::eR64G64B64A64Uint: return "R64G64B64A64Uint";\r
+ case Format::eR64G64B64A64Sint: return "R64G64B64A64Sint";\r
+ case Format::eR64G64B64A64Sfloat: return "R64G64B64A64Sfloat";\r
+ case Format::eB10G11R11UfloatPack32: return "B10G11R11UfloatPack32";\r
+ case Format::eE5B9G9R9UfloatPack32: return "E5B9G9R9UfloatPack32";\r
+ case Format::eD16Unorm: return "D16Unorm";\r
+ case Format::eX8D24UnormPack32: return "X8D24UnormPack32";\r
+ case Format::eD32Sfloat: return "D32Sfloat";\r
+ case Format::eS8Uint: return "S8Uint";\r
+ case Format::eD16UnormS8Uint: return "D16UnormS8Uint";\r
+ case Format::eD24UnormS8Uint: return "D24UnormS8Uint";\r
+ case Format::eD32SfloatS8Uint: return "D32SfloatS8Uint";\r
+ case Format::eBc1RgbUnormBlock: return "Bc1RgbUnormBlock";\r
+ case Format::eBc1RgbSrgbBlock: return "Bc1RgbSrgbBlock";\r
+ case Format::eBc1RgbaUnormBlock: return "Bc1RgbaUnormBlock";\r
+ case Format::eBc1RgbaSrgbBlock: return "Bc1RgbaSrgbBlock";\r
+ case Format::eBc2UnormBlock: return "Bc2UnormBlock";\r
+ case Format::eBc2SrgbBlock: return "Bc2SrgbBlock";\r
+ case Format::eBc3UnormBlock: return "Bc3UnormBlock";\r
+ case Format::eBc3SrgbBlock: return "Bc3SrgbBlock";\r
+ case Format::eBc4UnormBlock: return "Bc4UnormBlock";\r
+ case Format::eBc4SnormBlock: return "Bc4SnormBlock";\r
+ case Format::eBc5UnormBlock: return "Bc5UnormBlock";\r
+ case Format::eBc5SnormBlock: return "Bc5SnormBlock";\r
+ case Format::eBc6HUfloatBlock: return "Bc6HUfloatBlock";\r
+ case Format::eBc6HSfloatBlock: return "Bc6HSfloatBlock";\r
+ case Format::eBc7UnormBlock: return "Bc7UnormBlock";\r
+ case Format::eBc7SrgbBlock: return "Bc7SrgbBlock";\r
+ case Format::eEtc2R8G8B8UnormBlock: return "Etc2R8G8B8UnormBlock";\r
+ case Format::eEtc2R8G8B8SrgbBlock: return "Etc2R8G8B8SrgbBlock";\r
+ case Format::eEtc2R8G8B8A1UnormBlock: return "Etc2R8G8B8A1UnormBlock";\r
+ case Format::eEtc2R8G8B8A1SrgbBlock: return "Etc2R8G8B8A1SrgbBlock";\r
+ case Format::eEtc2R8G8B8A8UnormBlock: return "Etc2R8G8B8A8UnormBlock";\r
+ case Format::eEtc2R8G8B8A8SrgbBlock: return "Etc2R8G8B8A8SrgbBlock";\r
+ case Format::eEacR11UnormBlock: return "EacR11UnormBlock";\r
+ case Format::eEacR11SnormBlock: return "EacR11SnormBlock";\r
+ case Format::eEacR11G11UnormBlock: return "EacR11G11UnormBlock";\r
+ case Format::eEacR11G11SnormBlock: return "EacR11G11SnormBlock";\r
+ case Format::eAstc4x4UnormBlock: return "Astc4x4UnormBlock";\r
+ case Format::eAstc4x4SrgbBlock: return "Astc4x4SrgbBlock";\r
+ case Format::eAstc5x4UnormBlock: return "Astc5x4UnormBlock";\r
+ case Format::eAstc5x4SrgbBlock: return "Astc5x4SrgbBlock";\r
+ case Format::eAstc5x5UnormBlock: return "Astc5x5UnormBlock";\r
+ case Format::eAstc5x5SrgbBlock: return "Astc5x5SrgbBlock";\r
+ case Format::eAstc6x5UnormBlock: return "Astc6x5UnormBlock";\r
+ case Format::eAstc6x5SrgbBlock: return "Astc6x5SrgbBlock";\r
+ case Format::eAstc6x6UnormBlock: return "Astc6x6UnormBlock";\r
+ case Format::eAstc6x6SrgbBlock: return "Astc6x6SrgbBlock";\r
+ case Format::eAstc8x5UnormBlock: return "Astc8x5UnormBlock";\r
+ case Format::eAstc8x5SrgbBlock: return "Astc8x5SrgbBlock";\r
+ case Format::eAstc8x6UnormBlock: return "Astc8x6UnormBlock";\r
+ case Format::eAstc8x6SrgbBlock: return "Astc8x6SrgbBlock";\r
+ case Format::eAstc8x8UnormBlock: return "Astc8x8UnormBlock";\r
+ case Format::eAstc8x8SrgbBlock: return "Astc8x8SrgbBlock";\r
+ case Format::eAstc10x5UnormBlock: return "Astc10x5UnormBlock";\r
+ case Format::eAstc10x5SrgbBlock: return "Astc10x5SrgbBlock";\r
+ case Format::eAstc10x6UnormBlock: return "Astc10x6UnormBlock";\r
+ case Format::eAstc10x6SrgbBlock: return "Astc10x6SrgbBlock";\r
+ case Format::eAstc10x8UnormBlock: return "Astc10x8UnormBlock";\r
+ case Format::eAstc10x8SrgbBlock: return "Astc10x8SrgbBlock";\r
+ case Format::eAstc10x10UnormBlock: return "Astc10x10UnormBlock";\r
+ case Format::eAstc10x10SrgbBlock: return "Astc10x10SrgbBlock";\r
+ case Format::eAstc12x10UnormBlock: return "Astc12x10UnormBlock";\r
+ case Format::eAstc12x10SrgbBlock: return "Astc12x10SrgbBlock";\r
+ case Format::eAstc12x12UnormBlock: return "Astc12x12UnormBlock";\r
+ case Format::eAstc12x12SrgbBlock: return "Astc12x12SrgbBlock";\r
+ case Format::eG8B8G8R8422Unorm: return "G8B8G8R8422Unorm";\r
+ case Format::eB8G8R8G8422Unorm: return "B8G8R8G8422Unorm";\r
+ case Format::eG8B8R83Plane420Unorm: return "G8B8R83Plane420Unorm";\r
+ case Format::eG8B8R82Plane420Unorm: return "G8B8R82Plane420Unorm";\r
+ case Format::eG8B8R83Plane422Unorm: return "G8B8R83Plane422Unorm";\r
+ case Format::eG8B8R82Plane422Unorm: return "G8B8R82Plane422Unorm";\r
+ case Format::eG8B8R83Plane444Unorm: return "G8B8R83Plane444Unorm";\r
+ case Format::eR10X6UnormPack16: return "R10X6UnormPack16";\r
+ case Format::eR10X6G10X6Unorm2Pack16: return "R10X6G10X6Unorm2Pack16";\r
+ case Format::eR10X6G10X6B10X6A10X6Unorm4Pack16: return "R10X6G10X6B10X6A10X6Unorm4Pack16";\r
+ case Format::eG10X6B10X6G10X6R10X6422Unorm4Pack16: return "G10X6B10X6G10X6R10X6422Unorm4Pack16";\r
+ case Format::eB10X6G10X6R10X6G10X6422Unorm4Pack16: return "B10X6G10X6R10X6G10X6422Unorm4Pack16";\r
+ case Format::eG10X6B10X6R10X63Plane420Unorm3Pack16: return "G10X6B10X6R10X63Plane420Unorm3Pack16";\r
+ case Format::eG10X6B10X6R10X62Plane420Unorm3Pack16: return "G10X6B10X6R10X62Plane420Unorm3Pack16";\r
+ case Format::eG10X6B10X6R10X63Plane422Unorm3Pack16: return "G10X6B10X6R10X63Plane422Unorm3Pack16";\r
+ case Format::eG10X6B10X6R10X62Plane422Unorm3Pack16: return "G10X6B10X6R10X62Plane422Unorm3Pack16";\r
+ case Format::eG10X6B10X6R10X63Plane444Unorm3Pack16: return "G10X6B10X6R10X63Plane444Unorm3Pack16";\r
+ case Format::eR12X4UnormPack16: return "R12X4UnormPack16";\r
+ case Format::eR12X4G12X4Unorm2Pack16: return "R12X4G12X4Unorm2Pack16";\r
+ case Format::eR12X4G12X4B12X4A12X4Unorm4Pack16: return "R12X4G12X4B12X4A12X4Unorm4Pack16";\r
+ case Format::eG12X4B12X4G12X4R12X4422Unorm4Pack16: return "G12X4B12X4G12X4R12X4422Unorm4Pack16";\r
+ case Format::eB12X4G12X4R12X4G12X4422Unorm4Pack16: return "B12X4G12X4R12X4G12X4422Unorm4Pack16";\r
+ case Format::eG12X4B12X4R12X43Plane420Unorm3Pack16: return "G12X4B12X4R12X43Plane420Unorm3Pack16";\r
+ case Format::eG12X4B12X4R12X42Plane420Unorm3Pack16: return "G12X4B12X4R12X42Plane420Unorm3Pack16";\r
+ case Format::eG12X4B12X4R12X43Plane422Unorm3Pack16: return "G12X4B12X4R12X43Plane422Unorm3Pack16";\r
+ case Format::eG12X4B12X4R12X42Plane422Unorm3Pack16: return "G12X4B12X4R12X42Plane422Unorm3Pack16";\r
+ case Format::eG12X4B12X4R12X43Plane444Unorm3Pack16: return "G12X4B12X4R12X43Plane444Unorm3Pack16";\r
+ case Format::eG16B16G16R16422Unorm: return "G16B16G16R16422Unorm";\r
+ case Format::eB16G16R16G16422Unorm: return "B16G16R16G16422Unorm";\r
+ case Format::eG16B16R163Plane420Unorm: return "G16B16R163Plane420Unorm";\r
+ case Format::eG16B16R162Plane420Unorm: return "G16B16R162Plane420Unorm";\r
+ case Format::eG16B16R163Plane422Unorm: return "G16B16R163Plane422Unorm";\r
+ case Format::eG16B16R162Plane422Unorm: return "G16B16R162Plane422Unorm";\r
+ case Format::eG16B16R163Plane444Unorm: return "G16B16R163Plane444Unorm";\r
+ case Format::ePvrtc12BppUnormBlockIMG: return "Pvrtc12BppUnormBlockIMG";\r
+ case Format::ePvrtc14BppUnormBlockIMG: return "Pvrtc14BppUnormBlockIMG";\r
+ case Format::ePvrtc22BppUnormBlockIMG: return "Pvrtc22BppUnormBlockIMG";\r
+ case Format::ePvrtc24BppUnormBlockIMG: return "Pvrtc24BppUnormBlockIMG";\r
+ case Format::ePvrtc12BppSrgbBlockIMG: return "Pvrtc12BppSrgbBlockIMG";\r
+ case Format::ePvrtc14BppSrgbBlockIMG: return "Pvrtc14BppSrgbBlockIMG";\r
+ case Format::ePvrtc22BppSrgbBlockIMG: return "Pvrtc22BppSrgbBlockIMG";\r
+ case Format::ePvrtc24BppSrgbBlockIMG: return "Pvrtc24BppSrgbBlockIMG";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(StructureType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case StructureType::eApplicationInfo: return "ApplicationInfo";\r
+ case StructureType::eInstanceCreateInfo: return "InstanceCreateInfo";\r
+ case StructureType::eDeviceQueueCreateInfo: return "DeviceQueueCreateInfo";\r
+ case StructureType::eDeviceCreateInfo: return "DeviceCreateInfo";\r
+ case StructureType::eSubmitInfo: return "SubmitInfo";\r
+ case StructureType::eMemoryAllocateInfo: return "MemoryAllocateInfo";\r
+ case StructureType::eMappedMemoryRange: return "MappedMemoryRange";\r
+ case StructureType::eBindSparseInfo: return "BindSparseInfo";\r
+ case StructureType::eFenceCreateInfo: return "FenceCreateInfo";\r
+ case StructureType::eSemaphoreCreateInfo: return "SemaphoreCreateInfo";\r
+ case StructureType::eEventCreateInfo: return "EventCreateInfo";\r
+ case StructureType::eQueryPoolCreateInfo: return "QueryPoolCreateInfo";\r
+ case StructureType::eBufferCreateInfo: return "BufferCreateInfo";\r
+ case StructureType::eBufferViewCreateInfo: return "BufferViewCreateInfo";\r
+ case StructureType::eImageCreateInfo: return "ImageCreateInfo";\r
+ case StructureType::eImageViewCreateInfo: return "ImageViewCreateInfo";\r
+ case StructureType::eShaderModuleCreateInfo: return "ShaderModuleCreateInfo";\r
+ case StructureType::ePipelineCacheCreateInfo: return "PipelineCacheCreateInfo";\r
+ case StructureType::ePipelineShaderStageCreateInfo: return "PipelineShaderStageCreateInfo";\r
+ case StructureType::ePipelineVertexInputStateCreateInfo: return "PipelineVertexInputStateCreateInfo";\r
+ case StructureType::ePipelineInputAssemblyStateCreateInfo: return "PipelineInputAssemblyStateCreateInfo";\r
+ case StructureType::ePipelineTessellationStateCreateInfo: return "PipelineTessellationStateCreateInfo";\r
+ case StructureType::ePipelineViewportStateCreateInfo: return "PipelineViewportStateCreateInfo";\r
+ case StructureType::ePipelineRasterizationStateCreateInfo: return "PipelineRasterizationStateCreateInfo";\r
+ case StructureType::ePipelineMultisampleStateCreateInfo: return "PipelineMultisampleStateCreateInfo";\r
+ case StructureType::ePipelineDepthStencilStateCreateInfo: return "PipelineDepthStencilStateCreateInfo";\r
+ case StructureType::ePipelineColorBlendStateCreateInfo: return "PipelineColorBlendStateCreateInfo";\r
+ case StructureType::ePipelineDynamicStateCreateInfo: return "PipelineDynamicStateCreateInfo";\r
+ case StructureType::eGraphicsPipelineCreateInfo: return "GraphicsPipelineCreateInfo";\r
+ case StructureType::eComputePipelineCreateInfo: return "ComputePipelineCreateInfo";\r
+ case StructureType::ePipelineLayoutCreateInfo: return "PipelineLayoutCreateInfo";\r
+ case StructureType::eSamplerCreateInfo: return "SamplerCreateInfo";\r
+ case StructureType::eDescriptorSetLayoutCreateInfo: return "DescriptorSetLayoutCreateInfo";\r
+ case StructureType::eDescriptorPoolCreateInfo: return "DescriptorPoolCreateInfo";\r
+ case StructureType::eDescriptorSetAllocateInfo: return "DescriptorSetAllocateInfo";\r
+ case StructureType::eWriteDescriptorSet: return "WriteDescriptorSet";\r
+ case StructureType::eCopyDescriptorSet: return "CopyDescriptorSet";\r
+ case StructureType::eFramebufferCreateInfo: return "FramebufferCreateInfo";\r
+ case StructureType::eRenderPassCreateInfo: return "RenderPassCreateInfo";\r
+ case StructureType::eCommandPoolCreateInfo: return "CommandPoolCreateInfo";\r
+ case StructureType::eCommandBufferAllocateInfo: return "CommandBufferAllocateInfo";\r
+ case StructureType::eCommandBufferInheritanceInfo: return "CommandBufferInheritanceInfo";\r
+ case StructureType::eCommandBufferBeginInfo: return "CommandBufferBeginInfo";\r
+ case StructureType::eRenderPassBeginInfo: return "RenderPassBeginInfo";\r
+ case StructureType::eBufferMemoryBarrier: return "BufferMemoryBarrier";\r
+ case StructureType::eImageMemoryBarrier: return "ImageMemoryBarrier";\r
+ case StructureType::eMemoryBarrier: return "MemoryBarrier";\r
+ case StructureType::eLoaderInstanceCreateInfo: return "LoaderInstanceCreateInfo";\r
+ case StructureType::eLoaderDeviceCreateInfo: return "LoaderDeviceCreateInfo";\r
+ case StructureType::ePhysicalDeviceSubgroupProperties: return "PhysicalDeviceSubgroupProperties";\r
+ case StructureType::eBindBufferMemoryInfo: return "BindBufferMemoryInfo";\r
+ case StructureType::eBindImageMemoryInfo: return "BindImageMemoryInfo";\r
+ case StructureType::ePhysicalDevice16BitStorageFeatures: return "PhysicalDevice16BitStorageFeatures";\r
+ case StructureType::eMemoryDedicatedRequirements: return "MemoryDedicatedRequirements";\r
+ case StructureType::eMemoryDedicatedAllocateInfo: return "MemoryDedicatedAllocateInfo";\r
+ case StructureType::eMemoryAllocateFlagsInfo: return "MemoryAllocateFlagsInfo";\r
+ case StructureType::eDeviceGroupRenderPassBeginInfo: return "DeviceGroupRenderPassBeginInfo";\r
+ case StructureType::eDeviceGroupCommandBufferBeginInfo: return "DeviceGroupCommandBufferBeginInfo";\r
+ case StructureType::eDeviceGroupSubmitInfo: return "DeviceGroupSubmitInfo";\r
+ case StructureType::eDeviceGroupBindSparseInfo: return "DeviceGroupBindSparseInfo";\r
+ case StructureType::eBindBufferMemoryDeviceGroupInfo: return "BindBufferMemoryDeviceGroupInfo";\r
+ case StructureType::eBindImageMemoryDeviceGroupInfo: return "BindImageMemoryDeviceGroupInfo";\r
+ case StructureType::ePhysicalDeviceGroupProperties: return "PhysicalDeviceGroupProperties";\r
+ case StructureType::eDeviceGroupDeviceCreateInfo: return "DeviceGroupDeviceCreateInfo";\r
+ case StructureType::eBufferMemoryRequirementsInfo2: return "BufferMemoryRequirementsInfo2";\r
+ case StructureType::eImageMemoryRequirementsInfo2: return "ImageMemoryRequirementsInfo2";\r
+ case StructureType::eImageSparseMemoryRequirementsInfo2: return "ImageSparseMemoryRequirementsInfo2";\r
+ case StructureType::eMemoryRequirements2: return "MemoryRequirements2";\r
+ case StructureType::eSparseImageMemoryRequirements2: return "SparseImageMemoryRequirements2";\r
+ case StructureType::ePhysicalDeviceFeatures2: return "PhysicalDeviceFeatures2";\r
+ case StructureType::ePhysicalDeviceProperties2: return "PhysicalDeviceProperties2";\r
+ case StructureType::eFormatProperties2: return "FormatProperties2";\r
+ case StructureType::eImageFormatProperties2: return "ImageFormatProperties2";\r
+ case StructureType::ePhysicalDeviceImageFormatInfo2: return "PhysicalDeviceImageFormatInfo2";\r
+ case StructureType::eQueueFamilyProperties2: return "QueueFamilyProperties2";\r
+ case StructureType::ePhysicalDeviceMemoryProperties2: return "PhysicalDeviceMemoryProperties2";\r
+ case StructureType::eSparseImageFormatProperties2: return "SparseImageFormatProperties2";\r
+ case StructureType::ePhysicalDeviceSparseImageFormatInfo2: return "PhysicalDeviceSparseImageFormatInfo2";\r
+ case StructureType::ePhysicalDevicePointClippingProperties: return "PhysicalDevicePointClippingProperties";\r
+ case StructureType::eRenderPassInputAttachmentAspectCreateInfo: return "RenderPassInputAttachmentAspectCreateInfo";\r
+ case StructureType::eImageViewUsageCreateInfo: return "ImageViewUsageCreateInfo";\r
+ case StructureType::ePipelineTessellationDomainOriginStateCreateInfo: return "PipelineTessellationDomainOriginStateCreateInfo";\r
+ case StructureType::eRenderPassMultiviewCreateInfo: return "RenderPassMultiviewCreateInfo";\r
+ case StructureType::ePhysicalDeviceMultiviewFeatures: return "PhysicalDeviceMultiviewFeatures";\r
+ case StructureType::ePhysicalDeviceMultiviewProperties: return "PhysicalDeviceMultiviewProperties";\r
+ case StructureType::ePhysicalDeviceVariablePointerFeatures: return "PhysicalDeviceVariablePointerFeatures";\r
+ case StructureType::eProtectedSubmitInfo: return "ProtectedSubmitInfo";\r
+ case StructureType::ePhysicalDeviceProtectedMemoryFeatures: return "PhysicalDeviceProtectedMemoryFeatures";\r
+ case StructureType::ePhysicalDeviceProtectedMemoryProperties: return "PhysicalDeviceProtectedMemoryProperties";\r
+ case StructureType::eDeviceQueueInfo2: return "DeviceQueueInfo2";\r
+ case StructureType::eSamplerYcbcrConversionCreateInfo: return "SamplerYcbcrConversionCreateInfo";\r
+ case StructureType::eSamplerYcbcrConversionInfo: return "SamplerYcbcrConversionInfo";\r
+ case StructureType::eBindImagePlaneMemoryInfo: return "BindImagePlaneMemoryInfo";\r
+ case StructureType::eImagePlaneMemoryRequirementsInfo: return "ImagePlaneMemoryRequirementsInfo";\r
+ case StructureType::ePhysicalDeviceSamplerYcbcrConversionFeatures: return "PhysicalDeviceSamplerYcbcrConversionFeatures";\r
+ case StructureType::eSamplerYcbcrConversionImageFormatProperties: return "SamplerYcbcrConversionImageFormatProperties";\r
+ case StructureType::eDescriptorUpdateTemplateCreateInfo: return "DescriptorUpdateTemplateCreateInfo";\r
+ case StructureType::ePhysicalDeviceExternalImageFormatInfo: return "PhysicalDeviceExternalImageFormatInfo";\r
+ case StructureType::eExternalImageFormatProperties: return "ExternalImageFormatProperties";\r
+ case StructureType::ePhysicalDeviceExternalBufferInfo: return "PhysicalDeviceExternalBufferInfo";\r
+ case StructureType::eExternalBufferProperties: return "ExternalBufferProperties";\r
+ case StructureType::ePhysicalDeviceIdProperties: return "PhysicalDeviceIdProperties";\r
+ case StructureType::eExternalMemoryBufferCreateInfo: return "ExternalMemoryBufferCreateInfo";\r
+ case StructureType::eExternalMemoryImageCreateInfo: return "ExternalMemoryImageCreateInfo";\r
+ case StructureType::eExportMemoryAllocateInfo: return "ExportMemoryAllocateInfo";\r
+ case StructureType::ePhysicalDeviceExternalFenceInfo: return "PhysicalDeviceExternalFenceInfo";\r
+ case StructureType::eExternalFenceProperties: return "ExternalFenceProperties";\r
+ case StructureType::eExportFenceCreateInfo: return "ExportFenceCreateInfo";\r
+ case StructureType::eExportSemaphoreCreateInfo: return "ExportSemaphoreCreateInfo";\r
+ case StructureType::ePhysicalDeviceExternalSemaphoreInfo: return "PhysicalDeviceExternalSemaphoreInfo";\r
+ case StructureType::eExternalSemaphoreProperties: return "ExternalSemaphoreProperties";\r
+ case StructureType::ePhysicalDeviceMaintenance3Properties: return "PhysicalDeviceMaintenance3Properties";\r
+ case StructureType::eDescriptorSetLayoutSupport: return "DescriptorSetLayoutSupport";\r
+ case StructureType::ePhysicalDeviceShaderDrawParameterFeatures: return "PhysicalDeviceShaderDrawParameterFeatures";\r
+ case StructureType::eSwapchainCreateInfoKHR: return "SwapchainCreateInfoKHR";\r
+ case StructureType::ePresentInfoKHR: return "PresentInfoKHR";\r
+ case StructureType::eDeviceGroupPresentCapabilitiesKHR: return "DeviceGroupPresentCapabilitiesKHR";\r
+ case StructureType::eImageSwapchainCreateInfoKHR: return "ImageSwapchainCreateInfoKHR";\r
+ case StructureType::eBindImageMemorySwapchainInfoKHR: return "BindImageMemorySwapchainInfoKHR";\r
+ case StructureType::eAcquireNextImageInfoKHR: return "AcquireNextImageInfoKHR";\r
+ case StructureType::eDeviceGroupPresentInfoKHR: return "DeviceGroupPresentInfoKHR";\r
+ case StructureType::eDeviceGroupSwapchainCreateInfoKHR: return "DeviceGroupSwapchainCreateInfoKHR";\r
+ case StructureType::eDisplayModeCreateInfoKHR: return "DisplayModeCreateInfoKHR";\r
+ case StructureType::eDisplaySurfaceCreateInfoKHR: return "DisplaySurfaceCreateInfoKHR";\r
+ case StructureType::eDisplayPresentInfoKHR: return "DisplayPresentInfoKHR";\r
+ case StructureType::eXlibSurfaceCreateInfoKHR: return "XlibSurfaceCreateInfoKHR";\r
+ case StructureType::eXcbSurfaceCreateInfoKHR: return "XcbSurfaceCreateInfoKHR";\r
+ case StructureType::eWaylandSurfaceCreateInfoKHR: return "WaylandSurfaceCreateInfoKHR";\r
+ case StructureType::eMirSurfaceCreateInfoKHR: return "MirSurfaceCreateInfoKHR";\r
+ case StructureType::eAndroidSurfaceCreateInfoKHR: return "AndroidSurfaceCreateInfoKHR";\r
+ case StructureType::eWin32SurfaceCreateInfoKHR: return "Win32SurfaceCreateInfoKHR";\r
+ case StructureType::eDebugReportCallbackCreateInfoEXT: return "DebugReportCallbackCreateInfoEXT";\r
+ case StructureType::ePipelineRasterizationStateRasterizationOrderAMD: return "PipelineRasterizationStateRasterizationOrderAMD";\r
+ case StructureType::eDebugMarkerObjectNameInfoEXT: return "DebugMarkerObjectNameInfoEXT";\r
+ case StructureType::eDebugMarkerObjectTagInfoEXT: return "DebugMarkerObjectTagInfoEXT";\r
+ case StructureType::eDebugMarkerMarkerInfoEXT: return "DebugMarkerMarkerInfoEXT";\r
+ case StructureType::eDedicatedAllocationImageCreateInfoNV: return "DedicatedAllocationImageCreateInfoNV";\r
+ case StructureType::eDedicatedAllocationBufferCreateInfoNV: return "DedicatedAllocationBufferCreateInfoNV";\r
+ case StructureType::eDedicatedAllocationMemoryAllocateInfoNV: return "DedicatedAllocationMemoryAllocateInfoNV";\r
+ case StructureType::eTextureLodGatherFormatPropertiesAMD: return "TextureLodGatherFormatPropertiesAMD";\r
+ case StructureType::eExternalMemoryImageCreateInfoNV: return "ExternalMemoryImageCreateInfoNV";\r
+ case StructureType::eExportMemoryAllocateInfoNV: return "ExportMemoryAllocateInfoNV";\r
+ case StructureType::eImportMemoryWin32HandleInfoNV: return "ImportMemoryWin32HandleInfoNV";\r
+ case StructureType::eExportMemoryWin32HandleInfoNV: return "ExportMemoryWin32HandleInfoNV";\r
+ case StructureType::eWin32KeyedMutexAcquireReleaseInfoNV: return "Win32KeyedMutexAcquireReleaseInfoNV";\r
+ case StructureType::eValidationFlagsEXT: return "ValidationFlagsEXT";\r
+ case StructureType::eViSurfaceCreateInfoNN: return "ViSurfaceCreateInfoNN";\r
+ case StructureType::eImportMemoryWin32HandleInfoKHR: return "ImportMemoryWin32HandleInfoKHR";\r
+ case StructureType::eExportMemoryWin32HandleInfoKHR: return "ExportMemoryWin32HandleInfoKHR";\r
+ case StructureType::eMemoryWin32HandlePropertiesKHR: return "MemoryWin32HandlePropertiesKHR";\r
+ case StructureType::eMemoryGetWin32HandleInfoKHR: return "MemoryGetWin32HandleInfoKHR";\r
+ case StructureType::eImportMemoryFdInfoKHR: return "ImportMemoryFdInfoKHR";\r
+ case StructureType::eMemoryFdPropertiesKHR: return "MemoryFdPropertiesKHR";\r
+ case StructureType::eMemoryGetFdInfoKHR: return "MemoryGetFdInfoKHR";\r
+ case StructureType::eWin32KeyedMutexAcquireReleaseInfoKHR: return "Win32KeyedMutexAcquireReleaseInfoKHR";\r
+ case StructureType::eImportSemaphoreWin32HandleInfoKHR: return "ImportSemaphoreWin32HandleInfoKHR";\r
+ case StructureType::eExportSemaphoreWin32HandleInfoKHR: return "ExportSemaphoreWin32HandleInfoKHR";\r
+ case StructureType::eD3D12FenceSubmitInfoKHR: return "D3D12FenceSubmitInfoKHR";\r
+ case StructureType::eSemaphoreGetWin32HandleInfoKHR: return "SemaphoreGetWin32HandleInfoKHR";\r
+ case StructureType::eImportSemaphoreFdInfoKHR: return "ImportSemaphoreFdInfoKHR";\r
+ case StructureType::eSemaphoreGetFdInfoKHR: return "SemaphoreGetFdInfoKHR";\r
+ case StructureType::ePhysicalDevicePushDescriptorPropertiesKHR: return "PhysicalDevicePushDescriptorPropertiesKHR";\r
+ case StructureType::ePresentRegionsKHR: return "PresentRegionsKHR";\r
+ case StructureType::eObjectTableCreateInfoNVX: return "ObjectTableCreateInfoNVX";\r
+ case StructureType::eIndirectCommandsLayoutCreateInfoNVX: return "IndirectCommandsLayoutCreateInfoNVX";\r
+ case StructureType::eCmdProcessCommandsInfoNVX: return "CmdProcessCommandsInfoNVX";\r
+ case StructureType::eCmdReserveSpaceForCommandsInfoNVX: return "CmdReserveSpaceForCommandsInfoNVX";\r
+ case StructureType::eDeviceGeneratedCommandsLimitsNVX: return "DeviceGeneratedCommandsLimitsNVX";\r
+ case StructureType::eDeviceGeneratedCommandsFeaturesNVX: return "DeviceGeneratedCommandsFeaturesNVX";\r
+ case StructureType::ePipelineViewportWScalingStateCreateInfoNV: return "PipelineViewportWScalingStateCreateInfoNV";\r
+ case StructureType::eSurfaceCapabilities2EXT: return "SurfaceCapabilities2EXT";\r
+ case StructureType::eDisplayPowerInfoEXT: return "DisplayPowerInfoEXT";\r
+ case StructureType::eDeviceEventInfoEXT: return "DeviceEventInfoEXT";\r
+ case StructureType::eDisplayEventInfoEXT: return "DisplayEventInfoEXT";\r
+ case StructureType::eSwapchainCounterCreateInfoEXT: return "SwapchainCounterCreateInfoEXT";\r
+ case StructureType::ePresentTimesInfoGOOGLE: return "PresentTimesInfoGOOGLE";\r
+ case StructureType::ePhysicalDeviceMultiviewPerViewAttributesPropertiesNVX: return "PhysicalDeviceMultiviewPerViewAttributesPropertiesNVX";\r
+ case StructureType::ePipelineViewportSwizzleStateCreateInfoNV: return "PipelineViewportSwizzleStateCreateInfoNV";\r
+ case StructureType::ePhysicalDeviceDiscardRectanglePropertiesEXT: return "PhysicalDeviceDiscardRectanglePropertiesEXT";\r
+ case StructureType::ePipelineDiscardRectangleStateCreateInfoEXT: return "PipelineDiscardRectangleStateCreateInfoEXT";\r
+ case StructureType::ePhysicalDeviceConservativeRasterizationPropertiesEXT: return "PhysicalDeviceConservativeRasterizationPropertiesEXT";\r
+ case StructureType::ePipelineRasterizationConservativeStateCreateInfoEXT: return "PipelineRasterizationConservativeStateCreateInfoEXT";\r
+ case StructureType::eHdrMetadataEXT: return "HdrMetadataEXT";\r
+ case StructureType::eSharedPresentSurfaceCapabilitiesKHR: return "SharedPresentSurfaceCapabilitiesKHR";\r
+ case StructureType::eImportFenceWin32HandleInfoKHR: return "ImportFenceWin32HandleInfoKHR";\r
+ case StructureType::eExportFenceWin32HandleInfoKHR: return "ExportFenceWin32HandleInfoKHR";\r
+ case StructureType::eFenceGetWin32HandleInfoKHR: return "FenceGetWin32HandleInfoKHR";\r
+ case StructureType::eImportFenceFdInfoKHR: return "ImportFenceFdInfoKHR";\r
+ case StructureType::eFenceGetFdInfoKHR: return "FenceGetFdInfoKHR";\r
+ case StructureType::ePhysicalDeviceSurfaceInfo2KHR: return "PhysicalDeviceSurfaceInfo2KHR";\r
+ case StructureType::eSurfaceCapabilities2KHR: return "SurfaceCapabilities2KHR";\r
+ case StructureType::eSurfaceFormat2KHR: return "SurfaceFormat2KHR";\r
+ case StructureType::eIosSurfaceCreateInfoMVK: return "IosSurfaceCreateInfoMVK";\r
+ case StructureType::eMacosSurfaceCreateInfoMVK: return "MacosSurfaceCreateInfoMVK";\r
+ case StructureType::eDebugUtilsObjectNameInfoEXT: return "DebugUtilsObjectNameInfoEXT";\r
+ case StructureType::eDebugUtilsObjectTagInfoEXT: return "DebugUtilsObjectTagInfoEXT";\r
+ case StructureType::eDebugUtilsLabelEXT: return "DebugUtilsLabelEXT";\r
+ case StructureType::eDebugUtilsMessengerCallbackDataEXT: return "DebugUtilsMessengerCallbackDataEXT";\r
+ case StructureType::eDebugUtilsMessengerCreateInfoEXT: return "DebugUtilsMessengerCreateInfoEXT";\r
+ case StructureType::eAndroidHardwareBufferUsageANDROID: return "AndroidHardwareBufferUsageANDROID";\r
+ case StructureType::eAndroidHardwareBufferPropertiesANDROID: return "AndroidHardwareBufferPropertiesANDROID";\r
+ case StructureType::eAndroidHardwareBufferFormatPropertiesANDROID: return "AndroidHardwareBufferFormatPropertiesANDROID";\r
+ case StructureType::eImportAndroidHardwareBufferInfoANDROID: return "ImportAndroidHardwareBufferInfoANDROID";\r
+ case StructureType::eMemoryGetAndroidHardwareBufferInfoANDROID: return "MemoryGetAndroidHardwareBufferInfoANDROID";\r
+ case StructureType::eExternalFormatANDROID: return "ExternalFormatANDROID";\r
+ case StructureType::ePhysicalDeviceSamplerFilterMinmaxPropertiesEXT: return "PhysicalDeviceSamplerFilterMinmaxPropertiesEXT";\r
+ case StructureType::eSamplerReductionModeCreateInfoEXT: return "SamplerReductionModeCreateInfoEXT";\r
+ case StructureType::eSampleLocationsInfoEXT: return "SampleLocationsInfoEXT";\r
+ case StructureType::eRenderPassSampleLocationsBeginInfoEXT: return "RenderPassSampleLocationsBeginInfoEXT";\r
+ case StructureType::ePipelineSampleLocationsStateCreateInfoEXT: return "PipelineSampleLocationsStateCreateInfoEXT";\r
+ case StructureType::ePhysicalDeviceSampleLocationsPropertiesEXT: return "PhysicalDeviceSampleLocationsPropertiesEXT";\r
+ case StructureType::eMultisamplePropertiesEXT: return "MultisamplePropertiesEXT";\r
+ case StructureType::eImageFormatListCreateInfoKHR: return "ImageFormatListCreateInfoKHR";\r
+ case StructureType::ePhysicalDeviceBlendOperationAdvancedFeaturesEXT: return "PhysicalDeviceBlendOperationAdvancedFeaturesEXT";\r
+ case StructureType::ePhysicalDeviceBlendOperationAdvancedPropertiesEXT: return "PhysicalDeviceBlendOperationAdvancedPropertiesEXT";\r
+ case StructureType::ePipelineColorBlendAdvancedStateCreateInfoEXT: return "PipelineColorBlendAdvancedStateCreateInfoEXT";\r
+ case StructureType::ePipelineCoverageToColorStateCreateInfoNV: return "PipelineCoverageToColorStateCreateInfoNV";\r
+ case StructureType::ePipelineCoverageModulationStateCreateInfoNV: return "PipelineCoverageModulationStateCreateInfoNV";\r
+ case StructureType::eValidationCacheCreateInfoEXT: return "ValidationCacheCreateInfoEXT";\r
+ case StructureType::eShaderModuleValidationCacheCreateInfoEXT: return "ShaderModuleValidationCacheCreateInfoEXT";\r
+ case StructureType::eDescriptorSetLayoutBindingFlagsCreateInfoEXT: return "DescriptorSetLayoutBindingFlagsCreateInfoEXT";\r
+ case StructureType::ePhysicalDeviceDescriptorIndexingFeaturesEXT: return "PhysicalDeviceDescriptorIndexingFeaturesEXT";\r
+ case StructureType::ePhysicalDeviceDescriptorIndexingPropertiesEXT: return "PhysicalDeviceDescriptorIndexingPropertiesEXT";\r
+ case StructureType::eDescriptorSetVariableDescriptorCountAllocateInfoEXT: return "DescriptorSetVariableDescriptorCountAllocateInfoEXT";\r
+ case StructureType::eDescriptorSetVariableDescriptorCountLayoutSupportEXT: return "DescriptorSetVariableDescriptorCountLayoutSupportEXT";\r
+ case StructureType::eDeviceQueueGlobalPriorityCreateInfoEXT: return "DeviceQueueGlobalPriorityCreateInfoEXT";\r
+ case StructureType::eImportMemoryHostPointerInfoEXT: return "ImportMemoryHostPointerInfoEXT";\r
+ case StructureType::eMemoryHostPointerPropertiesEXT: return "MemoryHostPointerPropertiesEXT";\r
+ case StructureType::ePhysicalDeviceExternalMemoryHostPropertiesEXT: return "PhysicalDeviceExternalMemoryHostPropertiesEXT";\r
+ case StructureType::ePhysicalDeviceShaderCorePropertiesAMD: return "PhysicalDeviceShaderCorePropertiesAMD";\r
+ case StructureType::ePhysicalDeviceVertexAttributeDivisorPropertiesEXT: return "PhysicalDeviceVertexAttributeDivisorPropertiesEXT";\r
+ case StructureType::ePipelineVertexInputDivisorStateCreateInfoEXT: return "PipelineVertexInputDivisorStateCreateInfoEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SubpassContents value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SubpassContents::eInline: return "Inline";\r
+ case SubpassContents::eSecondaryCommandBuffers: return "SecondaryCommandBuffers";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DynamicState value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DynamicState::eViewport: return "Viewport";\r
+ case DynamicState::eScissor: return "Scissor";\r
+ case DynamicState::eLineWidth: return "LineWidth";\r
+ case DynamicState::eDepthBias: return "DepthBias";\r
+ case DynamicState::eBlendConstants: return "BlendConstants";\r
+ case DynamicState::eDepthBounds: return "DepthBounds";\r
+ case DynamicState::eStencilCompareMask: return "StencilCompareMask";\r
+ case DynamicState::eStencilWriteMask: return "StencilWriteMask";\r
+ case DynamicState::eStencilReference: return "StencilReference";\r
+ case DynamicState::eViewportWScalingNV: return "ViewportWScalingNV";\r
+ case DynamicState::eDiscardRectangleEXT: return "DiscardRectangleEXT";\r
+ case DynamicState::eSampleLocationsEXT: return "SampleLocationsEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorUpdateTemplateType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DescriptorUpdateTemplateType::eDescriptorSet: return "DescriptorSet";\r
+ case DescriptorUpdateTemplateType::ePushDescriptorsKHR: return "PushDescriptorsKHR";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ObjectType value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ObjectType::eUnknown: return "Unknown";\r
+ case ObjectType::eInstance: return "Instance";\r
+ case ObjectType::ePhysicalDevice: return "PhysicalDevice";\r
+ case ObjectType::eDevice: return "Device";\r
+ case ObjectType::eQueue: return "Queue";\r
+ case ObjectType::eSemaphore: return "Semaphore";\r
+ case ObjectType::eCommandBuffer: return "CommandBuffer";\r
+ case ObjectType::eFence: return "Fence";\r
+ case ObjectType::eDeviceMemory: return "DeviceMemory";\r
+ case ObjectType::eBuffer: return "Buffer";\r
+ case ObjectType::eImage: return "Image";\r
+ case ObjectType::eEvent: return "Event";\r
+ case ObjectType::eQueryPool: return "QueryPool";\r
+ case ObjectType::eBufferView: return "BufferView";\r
+ case ObjectType::eImageView: return "ImageView";\r
+ case ObjectType::eShaderModule: return "ShaderModule";\r
+ case ObjectType::ePipelineCache: return "PipelineCache";\r
+ case ObjectType::ePipelineLayout: return "PipelineLayout";\r
+ case ObjectType::eRenderPass: return "RenderPass";\r
+ case ObjectType::ePipeline: return "Pipeline";\r
+ case ObjectType::eDescriptorSetLayout: return "DescriptorSetLayout";\r
+ case ObjectType::eSampler: return "Sampler";\r
+ case ObjectType::eDescriptorPool: return "DescriptorPool";\r
+ case ObjectType::eDescriptorSet: return "DescriptorSet";\r
+ case ObjectType::eFramebuffer: return "Framebuffer";\r
+ case ObjectType::eCommandPool: return "CommandPool";\r
+ case ObjectType::eSamplerYcbcrConversion: return "SamplerYcbcrConversion";\r
+ case ObjectType::eDescriptorUpdateTemplate: return "DescriptorUpdateTemplate";\r
+ case ObjectType::eSurfaceKHR: return "SurfaceKHR";\r
+ case ObjectType::eSwapchainKHR: return "SwapchainKHR";\r
+ case ObjectType::eDisplayKHR: return "DisplayKHR";\r
+ case ObjectType::eDisplayModeKHR: return "DisplayModeKHR";\r
+ case ObjectType::eDebugReportCallbackEXT: return "DebugReportCallbackEXT";\r
+ case ObjectType::eObjectTableNVX: return "ObjectTableNVX";\r
+ case ObjectType::eIndirectCommandsLayoutNVX: return "IndirectCommandsLayoutNVX";\r
+ case ObjectType::eDebugUtilsMessengerEXT: return "DebugUtilsMessengerEXT";\r
+ case ObjectType::eValidationCacheEXT: return "ValidationCacheEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueueFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case QueueFlagBits::eGraphics: return "Graphics";\r
+ case QueueFlagBits::eCompute: return "Compute";\r
+ case QueueFlagBits::eTransfer: return "Transfer";\r
+ case QueueFlagBits::eSparseBinding: return "SparseBinding";\r
+ case QueueFlagBits::eProtected: return "Protected";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueueFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & QueueFlagBits::eGraphics) result += "Graphics | ";\r
+ if (value & QueueFlagBits::eCompute) result += "Compute | ";\r
+ if (value & QueueFlagBits::eTransfer) result += "Transfer | ";\r
+ if (value & QueueFlagBits::eSparseBinding) result += "SparseBinding | ";\r
+ if (value & QueueFlagBits::eProtected) result += "Protected | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceQueueCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DeviceQueueCreateFlagBits::eProtected: return "Protected";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceQueueCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DeviceQueueCreateFlagBits::eProtected) result += "Protected | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryPropertyFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case MemoryPropertyFlagBits::eDeviceLocal: return "DeviceLocal";\r
+ case MemoryPropertyFlagBits::eHostVisible: return "HostVisible";\r
+ case MemoryPropertyFlagBits::eHostCoherent: return "HostCoherent";\r
+ case MemoryPropertyFlagBits::eHostCached: return "HostCached";\r
+ case MemoryPropertyFlagBits::eLazilyAllocated: return "LazilyAllocated";\r
+ case MemoryPropertyFlagBits::eProtected: return "Protected";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryPropertyFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & MemoryPropertyFlagBits::eDeviceLocal) result += "DeviceLocal | ";\r
+ if (value & MemoryPropertyFlagBits::eHostVisible) result += "HostVisible | ";\r
+ if (value & MemoryPropertyFlagBits::eHostCoherent) result += "HostCoherent | ";\r
+ if (value & MemoryPropertyFlagBits::eHostCached) result += "HostCached | ";\r
+ if (value & MemoryPropertyFlagBits::eLazilyAllocated) result += "LazilyAllocated | ";\r
+ if (value & MemoryPropertyFlagBits::eProtected) result += "Protected | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryHeapFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case MemoryHeapFlagBits::eDeviceLocal: return "DeviceLocal";\r
+ case MemoryHeapFlagBits::eMultiInstance: return "MultiInstance";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryHeapFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & MemoryHeapFlagBits::eDeviceLocal) result += "DeviceLocal | ";\r
+ if (value & MemoryHeapFlagBits::eMultiInstance) result += "MultiInstance | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(AccessFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case AccessFlagBits::eIndirectCommandRead: return "IndirectCommandRead";\r
+ case AccessFlagBits::eIndexRead: return "IndexRead";\r
+ case AccessFlagBits::eVertexAttributeRead: return "VertexAttributeRead";\r
+ case AccessFlagBits::eUniformRead: return "UniformRead";\r
+ case AccessFlagBits::eInputAttachmentRead: return "InputAttachmentRead";\r
+ case AccessFlagBits::eShaderRead: return "ShaderRead";\r
+ case AccessFlagBits::eShaderWrite: return "ShaderWrite";\r
+ case AccessFlagBits::eColorAttachmentRead: return "ColorAttachmentRead";\r
+ case AccessFlagBits::eColorAttachmentWrite: return "ColorAttachmentWrite";\r
+ case AccessFlagBits::eDepthStencilAttachmentRead: return "DepthStencilAttachmentRead";\r
+ case AccessFlagBits::eDepthStencilAttachmentWrite: return "DepthStencilAttachmentWrite";\r
+ case AccessFlagBits::eTransferRead: return "TransferRead";\r
+ case AccessFlagBits::eTransferWrite: return "TransferWrite";\r
+ case AccessFlagBits::eHostRead: return "HostRead";\r
+ case AccessFlagBits::eHostWrite: return "HostWrite";\r
+ case AccessFlagBits::eMemoryRead: return "MemoryRead";\r
+ case AccessFlagBits::eMemoryWrite: return "MemoryWrite";\r
+ case AccessFlagBits::eCommandProcessReadNVX: return "CommandProcessReadNVX";\r
+ case AccessFlagBits::eCommandProcessWriteNVX: return "CommandProcessWriteNVX";\r
+ case AccessFlagBits::eColorAttachmentReadNoncoherentEXT: return "ColorAttachmentReadNoncoherentEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(AccessFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & AccessFlagBits::eIndirectCommandRead) result += "IndirectCommandRead | ";\r
+ if (value & AccessFlagBits::eIndexRead) result += "IndexRead | ";\r
+ if (value & AccessFlagBits::eVertexAttributeRead) result += "VertexAttributeRead | ";\r
+ if (value & AccessFlagBits::eUniformRead) result += "UniformRead | ";\r
+ if (value & AccessFlagBits::eInputAttachmentRead) result += "InputAttachmentRead | ";\r
+ if (value & AccessFlagBits::eShaderRead) result += "ShaderRead | ";\r
+ if (value & AccessFlagBits::eShaderWrite) result += "ShaderWrite | ";\r
+ if (value & AccessFlagBits::eColorAttachmentRead) result += "ColorAttachmentRead | ";\r
+ if (value & AccessFlagBits::eColorAttachmentWrite) result += "ColorAttachmentWrite | ";\r
+ if (value & AccessFlagBits::eDepthStencilAttachmentRead) result += "DepthStencilAttachmentRead | ";\r
+ if (value & AccessFlagBits::eDepthStencilAttachmentWrite) result += "DepthStencilAttachmentWrite | ";\r
+ if (value & AccessFlagBits::eTransferRead) result += "TransferRead | ";\r
+ if (value & AccessFlagBits::eTransferWrite) result += "TransferWrite | ";\r
+ if (value & AccessFlagBits::eHostRead) result += "HostRead | ";\r
+ if (value & AccessFlagBits::eHostWrite) result += "HostWrite | ";\r
+ if (value & AccessFlagBits::eMemoryRead) result += "MemoryRead | ";\r
+ if (value & AccessFlagBits::eMemoryWrite) result += "MemoryWrite | ";\r
+ if (value & AccessFlagBits::eCommandProcessReadNVX) result += "CommandProcessReadNVX | ";\r
+ if (value & AccessFlagBits::eCommandProcessWriteNVX) result += "CommandProcessWriteNVX | ";\r
+ if (value & AccessFlagBits::eColorAttachmentReadNoncoherentEXT) result += "ColorAttachmentReadNoncoherentEXT | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BufferUsageFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case BufferUsageFlagBits::eTransferSrc: return "TransferSrc";\r
+ case BufferUsageFlagBits::eTransferDst: return "TransferDst";\r
+ case BufferUsageFlagBits::eUniformTexelBuffer: return "UniformTexelBuffer";\r
+ case BufferUsageFlagBits::eStorageTexelBuffer: return "StorageTexelBuffer";\r
+ case BufferUsageFlagBits::eUniformBuffer: return "UniformBuffer";\r
+ case BufferUsageFlagBits::eStorageBuffer: return "StorageBuffer";\r
+ case BufferUsageFlagBits::eIndexBuffer: return "IndexBuffer";\r
+ case BufferUsageFlagBits::eVertexBuffer: return "VertexBuffer";\r
+ case BufferUsageFlagBits::eIndirectBuffer: return "IndirectBuffer";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BufferUsageFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & BufferUsageFlagBits::eTransferSrc) result += "TransferSrc | ";\r
+ if (value & BufferUsageFlagBits::eTransferDst) result += "TransferDst | ";\r
+ if (value & BufferUsageFlagBits::eUniformTexelBuffer) result += "UniformTexelBuffer | ";\r
+ if (value & BufferUsageFlagBits::eStorageTexelBuffer) result += "StorageTexelBuffer | ";\r
+ if (value & BufferUsageFlagBits::eUniformBuffer) result += "UniformBuffer | ";\r
+ if (value & BufferUsageFlagBits::eStorageBuffer) result += "StorageBuffer | ";\r
+ if (value & BufferUsageFlagBits::eIndexBuffer) result += "IndexBuffer | ";\r
+ if (value & BufferUsageFlagBits::eVertexBuffer) result += "VertexBuffer | ";\r
+ if (value & BufferUsageFlagBits::eIndirectBuffer) result += "IndirectBuffer | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BufferCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case BufferCreateFlagBits::eSparseBinding: return "SparseBinding";\r
+ case BufferCreateFlagBits::eSparseResidency: return "SparseResidency";\r
+ case BufferCreateFlagBits::eSparseAliased: return "SparseAliased";\r
+ case BufferCreateFlagBits::eProtected: return "Protected";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BufferCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & BufferCreateFlagBits::eSparseBinding) result += "SparseBinding | ";\r
+ if (value & BufferCreateFlagBits::eSparseResidency) result += "SparseResidency | ";\r
+ if (value & BufferCreateFlagBits::eSparseAliased) result += "SparseAliased | ";\r
+ if (value & BufferCreateFlagBits::eProtected) result += "Protected | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ShaderStageFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ShaderStageFlagBits::eVertex: return "Vertex";\r
+ case ShaderStageFlagBits::eTessellationControl: return "TessellationControl";\r
+ case ShaderStageFlagBits::eTessellationEvaluation: return "TessellationEvaluation";\r
+ case ShaderStageFlagBits::eGeometry: return "Geometry";\r
+ case ShaderStageFlagBits::eFragment: return "Fragment";\r
+ case ShaderStageFlagBits::eCompute: return "Compute";\r
+ case ShaderStageFlagBits::eAllGraphics: return "AllGraphics";\r
+ case ShaderStageFlagBits::eAll: return "All";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ShaderStageFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ShaderStageFlagBits::eVertex) result += "Vertex | ";\r
+ if (value & ShaderStageFlagBits::eTessellationControl) result += "TessellationControl | ";\r
+ if (value & ShaderStageFlagBits::eTessellationEvaluation) result += "TessellationEvaluation | ";\r
+ if (value & ShaderStageFlagBits::eGeometry) result += "Geometry | ";\r
+ if (value & ShaderStageFlagBits::eFragment) result += "Fragment | ";\r
+ if (value & ShaderStageFlagBits::eCompute) result += "Compute | ";\r
+ if (value & ShaderStageFlagBits::eAllGraphics) result += "AllGraphics | ";\r
+ if (value & ShaderStageFlagBits::eAll) result += "All | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageUsageFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageUsageFlagBits::eTransferSrc: return "TransferSrc";\r
+ case ImageUsageFlagBits::eTransferDst: return "TransferDst";\r
+ case ImageUsageFlagBits::eSampled: return "Sampled";\r
+ case ImageUsageFlagBits::eStorage: return "Storage";\r
+ case ImageUsageFlagBits::eColorAttachment: return "ColorAttachment";\r
+ case ImageUsageFlagBits::eDepthStencilAttachment: return "DepthStencilAttachment";\r
+ case ImageUsageFlagBits::eTransientAttachment: return "TransientAttachment";\r
+ case ImageUsageFlagBits::eInputAttachment: return "InputAttachment";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageUsageFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ImageUsageFlagBits::eTransferSrc) result += "TransferSrc | ";\r
+ if (value & ImageUsageFlagBits::eTransferDst) result += "TransferDst | ";\r
+ if (value & ImageUsageFlagBits::eSampled) result += "Sampled | ";\r
+ if (value & ImageUsageFlagBits::eStorage) result += "Storage | ";\r
+ if (value & ImageUsageFlagBits::eColorAttachment) result += "ColorAttachment | ";\r
+ if (value & ImageUsageFlagBits::eDepthStencilAttachment) result += "DepthStencilAttachment | ";\r
+ if (value & ImageUsageFlagBits::eTransientAttachment) result += "TransientAttachment | ";\r
+ if (value & ImageUsageFlagBits::eInputAttachment) result += "InputAttachment | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageCreateFlagBits::eSparseBinding: return "SparseBinding";\r
+ case ImageCreateFlagBits::eSparseResidency: return "SparseResidency";\r
+ case ImageCreateFlagBits::eSparseAliased: return "SparseAliased";\r
+ case ImageCreateFlagBits::eMutableFormat: return "MutableFormat";\r
+ case ImageCreateFlagBits::eCubeCompatible: return "CubeCompatible";\r
+ case ImageCreateFlagBits::eAlias: return "Alias";\r
+ case ImageCreateFlagBits::eSplitInstanceBindRegions: return "SplitInstanceBindRegions";\r
+ case ImageCreateFlagBits::e2DArrayCompatible: return "2DArrayCompatible";\r
+ case ImageCreateFlagBits::eBlockTexelViewCompatible: return "BlockTexelViewCompatible";\r
+ case ImageCreateFlagBits::eExtendedUsage: return "ExtendedUsage";\r
+ case ImageCreateFlagBits::eProtected: return "Protected";\r
+ case ImageCreateFlagBits::eDisjoint: return "Disjoint";\r
+ case ImageCreateFlagBits::eSampleLocationsCompatibleDepthEXT: return "SampleLocationsCompatibleDepthEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ImageCreateFlagBits::eSparseBinding) result += "SparseBinding | ";\r
+ if (value & ImageCreateFlagBits::eSparseResidency) result += "SparseResidency | ";\r
+ if (value & ImageCreateFlagBits::eSparseAliased) result += "SparseAliased | ";\r
+ if (value & ImageCreateFlagBits::eMutableFormat) result += "MutableFormat | ";\r
+ if (value & ImageCreateFlagBits::eCubeCompatible) result += "CubeCompatible | ";\r
+ if (value & ImageCreateFlagBits::eAlias) result += "Alias | ";\r
+ if (value & ImageCreateFlagBits::eSplitInstanceBindRegions) result += "SplitInstanceBindRegions | ";\r
+ if (value & ImageCreateFlagBits::e2DArrayCompatible) result += "2DArrayCompatible | ";\r
+ if (value & ImageCreateFlagBits::eBlockTexelViewCompatible) result += "BlockTexelViewCompatible | ";\r
+ if (value & ImageCreateFlagBits::eExtendedUsage) result += "ExtendedUsage | ";\r
+ if (value & ImageCreateFlagBits::eProtected) result += "Protected | ";\r
+ if (value & ImageCreateFlagBits::eDisjoint) result += "Disjoint | ";\r
+ if (value & ImageCreateFlagBits::eSampleLocationsCompatibleDepthEXT) result += "SampleLocationsCompatibleDepthEXT | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PipelineCreateFlagBits::eDisableOptimization: return "DisableOptimization";\r
+ case PipelineCreateFlagBits::eAllowDerivatives: return "AllowDerivatives";\r
+ case PipelineCreateFlagBits::eDerivative: return "Derivative";\r
+ case PipelineCreateFlagBits::eViewIndexFromDeviceIndex: return "ViewIndexFromDeviceIndex";\r
+ case PipelineCreateFlagBits::eDispatchBase: return "DispatchBase";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & PipelineCreateFlagBits::eDisableOptimization) result += "DisableOptimization | ";\r
+ if (value & PipelineCreateFlagBits::eAllowDerivatives) result += "AllowDerivatives | ";\r
+ if (value & PipelineCreateFlagBits::eDerivative) result += "Derivative | ";\r
+ if (value & PipelineCreateFlagBits::eViewIndexFromDeviceIndex) result += "ViewIndexFromDeviceIndex | ";\r
+ if (value & PipelineCreateFlagBits::eDispatchBase) result += "DispatchBase | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ColorComponentFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ColorComponentFlagBits::eR: return "R";\r
+ case ColorComponentFlagBits::eG: return "G";\r
+ case ColorComponentFlagBits::eB: return "B";\r
+ case ColorComponentFlagBits::eA: return "A";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ColorComponentFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ColorComponentFlagBits::eR) result += "R | ";\r
+ if (value & ColorComponentFlagBits::eG) result += "G | ";\r
+ if (value & ColorComponentFlagBits::eB) result += "B | ";\r
+ if (value & ColorComponentFlagBits::eA) result += "A | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FenceCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case FenceCreateFlagBits::eSignaled: return "Signaled";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FenceCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & FenceCreateFlagBits::eSignaled) result += "Signaled | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FormatFeatureFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case FormatFeatureFlagBits::eSampledImage: return "SampledImage";\r
+ case FormatFeatureFlagBits::eStorageImage: return "StorageImage";\r
+ case FormatFeatureFlagBits::eStorageImageAtomic: return "StorageImageAtomic";\r
+ case FormatFeatureFlagBits::eUniformTexelBuffer: return "UniformTexelBuffer";\r
+ case FormatFeatureFlagBits::eStorageTexelBuffer: return "StorageTexelBuffer";\r
+ case FormatFeatureFlagBits::eStorageTexelBufferAtomic: return "StorageTexelBufferAtomic";\r
+ case FormatFeatureFlagBits::eVertexBuffer: return "VertexBuffer";\r
+ case FormatFeatureFlagBits::eColorAttachment: return "ColorAttachment";\r
+ case FormatFeatureFlagBits::eColorAttachmentBlend: return "ColorAttachmentBlend";\r
+ case FormatFeatureFlagBits::eDepthStencilAttachment: return "DepthStencilAttachment";\r
+ case FormatFeatureFlagBits::eBlitSrc: return "BlitSrc";\r
+ case FormatFeatureFlagBits::eBlitDst: return "BlitDst";\r
+ case FormatFeatureFlagBits::eSampledImageFilterLinear: return "SampledImageFilterLinear";\r
+ case FormatFeatureFlagBits::eTransferSrc: return "TransferSrc";\r
+ case FormatFeatureFlagBits::eTransferDst: return "TransferDst";\r
+ case FormatFeatureFlagBits::eMidpointChromaSamples: return "MidpointChromaSamples";\r
+ case FormatFeatureFlagBits::eSampledImageYcbcrConversionLinearFilter: return "SampledImageYcbcrConversionLinearFilter";\r
+ case FormatFeatureFlagBits::eSampledImageYcbcrConversionSeparateReconstructionFilter: return "SampledImageYcbcrConversionSeparateReconstructionFilter";\r
+ case FormatFeatureFlagBits::eSampledImageYcbcrConversionChromaReconstructionExplicit: return "SampledImageYcbcrConversionChromaReconstructionExplicit";\r
+ case FormatFeatureFlagBits::eSampledImageYcbcrConversionChromaReconstructionExplicitForceable: return "SampledImageYcbcrConversionChromaReconstructionExplicitForceable";\r
+ case FormatFeatureFlagBits::eDisjoint: return "Disjoint";\r
+ case FormatFeatureFlagBits::eCositedChromaSamples: return "CositedChromaSamples";\r
+ case FormatFeatureFlagBits::eSampledImageFilterCubicIMG: return "SampledImageFilterCubicIMG";\r
+ case FormatFeatureFlagBits::eSampledImageFilterMinmaxEXT: return "SampledImageFilterMinmaxEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FormatFeatureFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & FormatFeatureFlagBits::eSampledImage) result += "SampledImage | ";\r
+ if (value & FormatFeatureFlagBits::eStorageImage) result += "StorageImage | ";\r
+ if (value & FormatFeatureFlagBits::eStorageImageAtomic) result += "StorageImageAtomic | ";\r
+ if (value & FormatFeatureFlagBits::eUniformTexelBuffer) result += "UniformTexelBuffer | ";\r
+ if (value & FormatFeatureFlagBits::eStorageTexelBuffer) result += "StorageTexelBuffer | ";\r
+ if (value & FormatFeatureFlagBits::eStorageTexelBufferAtomic) result += "StorageTexelBufferAtomic | ";\r
+ if (value & FormatFeatureFlagBits::eVertexBuffer) result += "VertexBuffer | ";\r
+ if (value & FormatFeatureFlagBits::eColorAttachment) result += "ColorAttachment | ";\r
+ if (value & FormatFeatureFlagBits::eColorAttachmentBlend) result += "ColorAttachmentBlend | ";\r
+ if (value & FormatFeatureFlagBits::eDepthStencilAttachment) result += "DepthStencilAttachment | ";\r
+ if (value & FormatFeatureFlagBits::eBlitSrc) result += "BlitSrc | ";\r
+ if (value & FormatFeatureFlagBits::eBlitDst) result += "BlitDst | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageFilterLinear) result += "SampledImageFilterLinear | ";\r
+ if (value & FormatFeatureFlagBits::eTransferSrc) result += "TransferSrc | ";\r
+ if (value & FormatFeatureFlagBits::eTransferDst) result += "TransferDst | ";\r
+ if (value & FormatFeatureFlagBits::eMidpointChromaSamples) result += "MidpointChromaSamples | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageYcbcrConversionLinearFilter) result += "SampledImageYcbcrConversionLinearFilter | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageYcbcrConversionSeparateReconstructionFilter) result += "SampledImageYcbcrConversionSeparateReconstructionFilter | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageYcbcrConversionChromaReconstructionExplicit) result += "SampledImageYcbcrConversionChromaReconstructionExplicit | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageYcbcrConversionChromaReconstructionExplicitForceable) result += "SampledImageYcbcrConversionChromaReconstructionExplicitForceable | ";\r
+ if (value & FormatFeatureFlagBits::eDisjoint) result += "Disjoint | ";\r
+ if (value & FormatFeatureFlagBits::eCositedChromaSamples) result += "CositedChromaSamples | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageFilterCubicIMG) result += "SampledImageFilterCubicIMG | ";\r
+ if (value & FormatFeatureFlagBits::eSampledImageFilterMinmaxEXT) result += "SampledImageFilterMinmaxEXT | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryControlFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case QueryControlFlagBits::ePrecise: return "Precise";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryControlFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & QueryControlFlagBits::ePrecise) result += "Precise | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryResultFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case QueryResultFlagBits::e64: return "64";\r
+ case QueryResultFlagBits::eWait: return "Wait";\r
+ case QueryResultFlagBits::eWithAvailability: return "WithAvailability";\r
+ case QueryResultFlagBits::ePartial: return "Partial";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryResultFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & QueryResultFlagBits::e64) result += "64 | ";\r
+ if (value & QueryResultFlagBits::eWait) result += "Wait | ";\r
+ if (value & QueryResultFlagBits::eWithAvailability) result += "WithAvailability | ";\r
+ if (value & QueryResultFlagBits::ePartial) result += "Partial | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandBufferUsageFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CommandBufferUsageFlagBits::eOneTimeSubmit: return "OneTimeSubmit";\r
+ case CommandBufferUsageFlagBits::eRenderPassContinue: return "RenderPassContinue";\r
+ case CommandBufferUsageFlagBits::eSimultaneousUse: return "SimultaneousUse";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandBufferUsageFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & CommandBufferUsageFlagBits::eOneTimeSubmit) result += "OneTimeSubmit | ";\r
+ if (value & CommandBufferUsageFlagBits::eRenderPassContinue) result += "RenderPassContinue | ";\r
+ if (value & CommandBufferUsageFlagBits::eSimultaneousUse) result += "SimultaneousUse | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryPipelineStatisticFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case QueryPipelineStatisticFlagBits::eInputAssemblyVertices: return "InputAssemblyVertices";\r
+ case QueryPipelineStatisticFlagBits::eInputAssemblyPrimitives: return "InputAssemblyPrimitives";\r
+ case QueryPipelineStatisticFlagBits::eVertexShaderInvocations: return "VertexShaderInvocations";\r
+ case QueryPipelineStatisticFlagBits::eGeometryShaderInvocations: return "GeometryShaderInvocations";\r
+ case QueryPipelineStatisticFlagBits::eGeometryShaderPrimitives: return "GeometryShaderPrimitives";\r
+ case QueryPipelineStatisticFlagBits::eClippingInvocations: return "ClippingInvocations";\r
+ case QueryPipelineStatisticFlagBits::eClippingPrimitives: return "ClippingPrimitives";\r
+ case QueryPipelineStatisticFlagBits::eFragmentShaderInvocations: return "FragmentShaderInvocations";\r
+ case QueryPipelineStatisticFlagBits::eTessellationControlShaderPatches: return "TessellationControlShaderPatches";\r
+ case QueryPipelineStatisticFlagBits::eTessellationEvaluationShaderInvocations: return "TessellationEvaluationShaderInvocations";\r
+ case QueryPipelineStatisticFlagBits::eComputeShaderInvocations: return "ComputeShaderInvocations";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueryPipelineStatisticFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & QueryPipelineStatisticFlagBits::eInputAssemblyVertices) result += "InputAssemblyVertices | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eInputAssemblyPrimitives) result += "InputAssemblyPrimitives | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eVertexShaderInvocations) result += "VertexShaderInvocations | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eGeometryShaderInvocations) result += "GeometryShaderInvocations | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eGeometryShaderPrimitives) result += "GeometryShaderPrimitives | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eClippingInvocations) result += "ClippingInvocations | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eClippingPrimitives) result += "ClippingPrimitives | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eFragmentShaderInvocations) result += "FragmentShaderInvocations | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eTessellationControlShaderPatches) result += "TessellationControlShaderPatches | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eTessellationEvaluationShaderInvocations) result += "TessellationEvaluationShaderInvocations | ";\r
+ if (value & QueryPipelineStatisticFlagBits::eComputeShaderInvocations) result += "ComputeShaderInvocations | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageAspectFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ImageAspectFlagBits::eColor: return "Color";\r
+ case ImageAspectFlagBits::eDepth: return "Depth";\r
+ case ImageAspectFlagBits::eStencil: return "Stencil";\r
+ case ImageAspectFlagBits::eMetadata: return "Metadata";\r
+ case ImageAspectFlagBits::ePlane0: return "Plane0";\r
+ case ImageAspectFlagBits::ePlane1: return "Plane1";\r
+ case ImageAspectFlagBits::ePlane2: return "Plane2";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ImageAspectFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ImageAspectFlagBits::eColor) result += "Color | ";\r
+ if (value & ImageAspectFlagBits::eDepth) result += "Depth | ";\r
+ if (value & ImageAspectFlagBits::eStencil) result += "Stencil | ";\r
+ if (value & ImageAspectFlagBits::eMetadata) result += "Metadata | ";\r
+ if (value & ImageAspectFlagBits::ePlane0) result += "Plane0 | ";\r
+ if (value & ImageAspectFlagBits::ePlane1) result += "Plane1 | ";\r
+ if (value & ImageAspectFlagBits::ePlane2) result += "Plane2 | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SparseImageFormatFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SparseImageFormatFlagBits::eSingleMiptail: return "SingleMiptail";\r
+ case SparseImageFormatFlagBits::eAlignedMipSize: return "AlignedMipSize";\r
+ case SparseImageFormatFlagBits::eNonstandardBlockSize: return "NonstandardBlockSize";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SparseImageFormatFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SparseImageFormatFlagBits::eSingleMiptail) result += "SingleMiptail | ";\r
+ if (value & SparseImageFormatFlagBits::eAlignedMipSize) result += "AlignedMipSize | ";\r
+ if (value & SparseImageFormatFlagBits::eNonstandardBlockSize) result += "NonstandardBlockSize | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SparseMemoryBindFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SparseMemoryBindFlagBits::eMetadata: return "Metadata";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SparseMemoryBindFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SparseMemoryBindFlagBits::eMetadata) result += "Metadata | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineStageFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PipelineStageFlagBits::eTopOfPipe: return "TopOfPipe";\r
+ case PipelineStageFlagBits::eDrawIndirect: return "DrawIndirect";\r
+ case PipelineStageFlagBits::eVertexInput: return "VertexInput";\r
+ case PipelineStageFlagBits::eVertexShader: return "VertexShader";\r
+ case PipelineStageFlagBits::eTessellationControlShader: return "TessellationControlShader";\r
+ case PipelineStageFlagBits::eTessellationEvaluationShader: return "TessellationEvaluationShader";\r
+ case PipelineStageFlagBits::eGeometryShader: return "GeometryShader";\r
+ case PipelineStageFlagBits::eFragmentShader: return "FragmentShader";\r
+ case PipelineStageFlagBits::eEarlyFragmentTests: return "EarlyFragmentTests";\r
+ case PipelineStageFlagBits::eLateFragmentTests: return "LateFragmentTests";\r
+ case PipelineStageFlagBits::eColorAttachmentOutput: return "ColorAttachmentOutput";\r
+ case PipelineStageFlagBits::eComputeShader: return "ComputeShader";\r
+ case PipelineStageFlagBits::eTransfer: return "Transfer";\r
+ case PipelineStageFlagBits::eBottomOfPipe: return "BottomOfPipe";\r
+ case PipelineStageFlagBits::eHost: return "Host";\r
+ case PipelineStageFlagBits::eAllGraphics: return "AllGraphics";\r
+ case PipelineStageFlagBits::eAllCommands: return "AllCommands";\r
+ case PipelineStageFlagBits::eCommandProcessNVX: return "CommandProcessNVX";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PipelineStageFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & PipelineStageFlagBits::eTopOfPipe) result += "TopOfPipe | ";\r
+ if (value & PipelineStageFlagBits::eDrawIndirect) result += "DrawIndirect | ";\r
+ if (value & PipelineStageFlagBits::eVertexInput) result += "VertexInput | ";\r
+ if (value & PipelineStageFlagBits::eVertexShader) result += "VertexShader | ";\r
+ if (value & PipelineStageFlagBits::eTessellationControlShader) result += "TessellationControlShader | ";\r
+ if (value & PipelineStageFlagBits::eTessellationEvaluationShader) result += "TessellationEvaluationShader | ";\r
+ if (value & PipelineStageFlagBits::eGeometryShader) result += "GeometryShader | ";\r
+ if (value & PipelineStageFlagBits::eFragmentShader) result += "FragmentShader | ";\r
+ if (value & PipelineStageFlagBits::eEarlyFragmentTests) result += "EarlyFragmentTests | ";\r
+ if (value & PipelineStageFlagBits::eLateFragmentTests) result += "LateFragmentTests | ";\r
+ if (value & PipelineStageFlagBits::eColorAttachmentOutput) result += "ColorAttachmentOutput | ";\r
+ if (value & PipelineStageFlagBits::eComputeShader) result += "ComputeShader | ";\r
+ if (value & PipelineStageFlagBits::eTransfer) result += "Transfer | ";\r
+ if (value & PipelineStageFlagBits::eBottomOfPipe) result += "BottomOfPipe | ";\r
+ if (value & PipelineStageFlagBits::eHost) result += "Host | ";\r
+ if (value & PipelineStageFlagBits::eAllGraphics) result += "AllGraphics | ";\r
+ if (value & PipelineStageFlagBits::eAllCommands) result += "AllCommands | ";\r
+ if (value & PipelineStageFlagBits::eCommandProcessNVX) result += "CommandProcessNVX | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandPoolCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CommandPoolCreateFlagBits::eTransient: return "Transient";\r
+ case CommandPoolCreateFlagBits::eResetCommandBuffer: return "ResetCommandBuffer";\r
+ case CommandPoolCreateFlagBits::eProtected: return "Protected";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandPoolCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & CommandPoolCreateFlagBits::eTransient) result += "Transient | ";\r
+ if (value & CommandPoolCreateFlagBits::eResetCommandBuffer) result += "ResetCommandBuffer | ";\r
+ if (value & CommandPoolCreateFlagBits::eProtected) result += "Protected | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandPoolResetFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CommandPoolResetFlagBits::eReleaseResources: return "ReleaseResources";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandPoolResetFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & CommandPoolResetFlagBits::eReleaseResources) result += "ReleaseResources | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandBufferResetFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CommandBufferResetFlagBits::eReleaseResources: return "ReleaseResources";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CommandBufferResetFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & CommandBufferResetFlagBits::eReleaseResources) result += "ReleaseResources | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SampleCountFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SampleCountFlagBits::e1: return "1";\r
+ case SampleCountFlagBits::e2: return "2";\r
+ case SampleCountFlagBits::e4: return "4";\r
+ case SampleCountFlagBits::e8: return "8";\r
+ case SampleCountFlagBits::e16: return "16";\r
+ case SampleCountFlagBits::e32: return "32";\r
+ case SampleCountFlagBits::e64: return "64";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SampleCountFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SampleCountFlagBits::e1) result += "1 | ";\r
+ if (value & SampleCountFlagBits::e2) result += "2 | ";\r
+ if (value & SampleCountFlagBits::e4) result += "4 | ";\r
+ if (value & SampleCountFlagBits::e8) result += "8 | ";\r
+ if (value & SampleCountFlagBits::e16) result += "16 | ";\r
+ if (value & SampleCountFlagBits::e32) result += "32 | ";\r
+ if (value & SampleCountFlagBits::e64) result += "64 | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(AttachmentDescriptionFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case AttachmentDescriptionFlagBits::eMayAlias: return "MayAlias";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(AttachmentDescriptionFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & AttachmentDescriptionFlagBits::eMayAlias) result += "MayAlias | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(StencilFaceFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case StencilFaceFlagBits::eFront: return "Front";\r
+ case StencilFaceFlagBits::eBack: return "Back";\r
+ case StencilFaceFlagBits::eVkStencilFrontAndBack: return "VkStencilFrontAndBack";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(StencilFaceFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & StencilFaceFlagBits::eFront) result += "Front | ";\r
+ if (value & StencilFaceFlagBits::eBack) result += "Back | ";\r
+ if (value & StencilFaceFlagBits::eVkStencilFrontAndBack) result += "VkStencilFrontAndBack | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorPoolCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DescriptorPoolCreateFlagBits::eFreeDescriptorSet: return "FreeDescriptorSet";\r
+ case DescriptorPoolCreateFlagBits::eUpdateAfterBindEXT: return "UpdateAfterBindEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorPoolCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DescriptorPoolCreateFlagBits::eFreeDescriptorSet) result += "FreeDescriptorSet | ";\r
+ if (value & DescriptorPoolCreateFlagBits::eUpdateAfterBindEXT) result += "UpdateAfterBindEXT | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DependencyFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DependencyFlagBits::eByRegion: return "ByRegion";\r
+ case DependencyFlagBits::eDeviceGroup: return "DeviceGroup";\r
+ case DependencyFlagBits::eViewLocal: return "ViewLocal";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DependencyFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DependencyFlagBits::eByRegion) result += "ByRegion | ";\r
+ if (value & DependencyFlagBits::eDeviceGroup) result += "DeviceGroup | ";\r
+ if (value & DependencyFlagBits::eViewLocal) result += "ViewLocal | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PresentModeKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PresentModeKHR::eImmediate: return "Immediate";\r
+ case PresentModeKHR::eMailbox: return "Mailbox";\r
+ case PresentModeKHR::eFifo: return "Fifo";\r
+ case PresentModeKHR::eFifoRelaxed: return "FifoRelaxed";\r
+ case PresentModeKHR::eSharedDemandRefresh: return "SharedDemandRefresh";\r
+ case PresentModeKHR::eSharedContinuousRefresh: return "SharedContinuousRefresh";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ColorSpaceKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ColorSpaceKHR::eSrgbNonlinear: return "SrgbNonlinear";\r
+ case ColorSpaceKHR::eDisplayP3NonlinearEXT: return "DisplayP3NonlinearEXT";\r
+ case ColorSpaceKHR::eExtendedSrgbLinearEXT: return "ExtendedSrgbLinearEXT";\r
+ case ColorSpaceKHR::eDciP3LinearEXT: return "DciP3LinearEXT";\r
+ case ColorSpaceKHR::eDciP3NonlinearEXT: return "DciP3NonlinearEXT";\r
+ case ColorSpaceKHR::eBt709LinearEXT: return "Bt709LinearEXT";\r
+ case ColorSpaceKHR::eBt709NonlinearEXT: return "Bt709NonlinearEXT";\r
+ case ColorSpaceKHR::eBt2020LinearEXT: return "Bt2020LinearEXT";\r
+ case ColorSpaceKHR::eHdr10St2084EXT: return "Hdr10St2084EXT";\r
+ case ColorSpaceKHR::eDolbyvisionEXT: return "DolbyvisionEXT";\r
+ case ColorSpaceKHR::eHdr10HlgEXT: return "Hdr10HlgEXT";\r
+ case ColorSpaceKHR::eAdobergbLinearEXT: return "AdobergbLinearEXT";\r
+ case ColorSpaceKHR::eAdobergbNonlinearEXT: return "AdobergbNonlinearEXT";\r
+ case ColorSpaceKHR::ePassThroughEXT: return "PassThroughEXT";\r
+ case ColorSpaceKHR::eExtendedSrgbNonlinearEXT: return "ExtendedSrgbNonlinearEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplayPlaneAlphaFlagBitsKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DisplayPlaneAlphaFlagBitsKHR::eOpaque: return "Opaque";\r
+ case DisplayPlaneAlphaFlagBitsKHR::eGlobal: return "Global";\r
+ case DisplayPlaneAlphaFlagBitsKHR::ePerPixel: return "PerPixel";\r
+ case DisplayPlaneAlphaFlagBitsKHR::ePerPixelPremultiplied: return "PerPixelPremultiplied";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplayPlaneAlphaFlagsKHR value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DisplayPlaneAlphaFlagBitsKHR::eOpaque) result += "Opaque | ";\r
+ if (value & DisplayPlaneAlphaFlagBitsKHR::eGlobal) result += "Global | ";\r
+ if (value & DisplayPlaneAlphaFlagBitsKHR::ePerPixel) result += "PerPixel | ";\r
+ if (value & DisplayPlaneAlphaFlagBitsKHR::ePerPixelPremultiplied) result += "PerPixelPremultiplied | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CompositeAlphaFlagBitsKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CompositeAlphaFlagBitsKHR::eOpaque: return "Opaque";\r
+ case CompositeAlphaFlagBitsKHR::ePreMultiplied: return "PreMultiplied";\r
+ case CompositeAlphaFlagBitsKHR::ePostMultiplied: return "PostMultiplied";\r
+ case CompositeAlphaFlagBitsKHR::eInherit: return "Inherit";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CompositeAlphaFlagsKHR value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & CompositeAlphaFlagBitsKHR::eOpaque) result += "Opaque | ";\r
+ if (value & CompositeAlphaFlagBitsKHR::ePreMultiplied) result += "PreMultiplied | ";\r
+ if (value & CompositeAlphaFlagBitsKHR::ePostMultiplied) result += "PostMultiplied | ";\r
+ if (value & CompositeAlphaFlagBitsKHR::eInherit) result += "Inherit | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SurfaceTransformFlagBitsKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SurfaceTransformFlagBitsKHR::eIdentity: return "Identity";\r
+ case SurfaceTransformFlagBitsKHR::eRotate90: return "Rotate90";\r
+ case SurfaceTransformFlagBitsKHR::eRotate180: return "Rotate180";\r
+ case SurfaceTransformFlagBitsKHR::eRotate270: return "Rotate270";\r
+ case SurfaceTransformFlagBitsKHR::eHorizontalMirror: return "HorizontalMirror";\r
+ case SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate90: return "HorizontalMirrorRotate90";\r
+ case SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate180: return "HorizontalMirrorRotate180";\r
+ case SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate270: return "HorizontalMirrorRotate270";\r
+ case SurfaceTransformFlagBitsKHR::eInherit: return "Inherit";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SurfaceTransformFlagsKHR value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SurfaceTransformFlagBitsKHR::eIdentity) result += "Identity | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eRotate90) result += "Rotate90 | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eRotate180) result += "Rotate180 | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eRotate270) result += "Rotate270 | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eHorizontalMirror) result += "HorizontalMirror | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate90) result += "HorizontalMirrorRotate90 | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate180) result += "HorizontalMirrorRotate180 | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eHorizontalMirrorRotate270) result += "HorizontalMirrorRotate270 | ";\r
+ if (value & SurfaceTransformFlagBitsKHR::eInherit) result += "Inherit | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugReportFlagBitsEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DebugReportFlagBitsEXT::eInformation: return "Information";\r
+ case DebugReportFlagBitsEXT::eWarning: return "Warning";\r
+ case DebugReportFlagBitsEXT::ePerformanceWarning: return "PerformanceWarning";\r
+ case DebugReportFlagBitsEXT::eError: return "Error";\r
+ case DebugReportFlagBitsEXT::eDebug: return "Debug";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugReportFlagsEXT value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DebugReportFlagBitsEXT::eInformation) result += "Information | ";\r
+ if (value & DebugReportFlagBitsEXT::eWarning) result += "Warning | ";\r
+ if (value & DebugReportFlagBitsEXT::ePerformanceWarning) result += "PerformanceWarning | ";\r
+ if (value & DebugReportFlagBitsEXT::eError) result += "Error | ";\r
+ if (value & DebugReportFlagBitsEXT::eDebug) result += "Debug | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugReportObjectTypeEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DebugReportObjectTypeEXT::eUnknown: return "Unknown";\r
+ case DebugReportObjectTypeEXT::eInstance: return "Instance";\r
+ case DebugReportObjectTypeEXT::ePhysicalDevice: return "PhysicalDevice";\r
+ case DebugReportObjectTypeEXT::eDevice: return "Device";\r
+ case DebugReportObjectTypeEXT::eQueue: return "Queue";\r
+ case DebugReportObjectTypeEXT::eSemaphore: return "Semaphore";\r
+ case DebugReportObjectTypeEXT::eCommandBuffer: return "CommandBuffer";\r
+ case DebugReportObjectTypeEXT::eFence: return "Fence";\r
+ case DebugReportObjectTypeEXT::eDeviceMemory: return "DeviceMemory";\r
+ case DebugReportObjectTypeEXT::eBuffer: return "Buffer";\r
+ case DebugReportObjectTypeEXT::eImage: return "Image";\r
+ case DebugReportObjectTypeEXT::eEvent: return "Event";\r
+ case DebugReportObjectTypeEXT::eQueryPool: return "QueryPool";\r
+ case DebugReportObjectTypeEXT::eBufferView: return "BufferView";\r
+ case DebugReportObjectTypeEXT::eImageView: return "ImageView";\r
+ case DebugReportObjectTypeEXT::eShaderModule: return "ShaderModule";\r
+ case DebugReportObjectTypeEXT::ePipelineCache: return "PipelineCache";\r
+ case DebugReportObjectTypeEXT::ePipelineLayout: return "PipelineLayout";\r
+ case DebugReportObjectTypeEXT::eRenderPass: return "RenderPass";\r
+ case DebugReportObjectTypeEXT::ePipeline: return "Pipeline";\r
+ case DebugReportObjectTypeEXT::eDescriptorSetLayout: return "DescriptorSetLayout";\r
+ case DebugReportObjectTypeEXT::eSampler: return "Sampler";\r
+ case DebugReportObjectTypeEXT::eDescriptorPool: return "DescriptorPool";\r
+ case DebugReportObjectTypeEXT::eDescriptorSet: return "DescriptorSet";\r
+ case DebugReportObjectTypeEXT::eFramebuffer: return "Framebuffer";\r
+ case DebugReportObjectTypeEXT::eCommandPool: return "CommandPool";\r
+ case DebugReportObjectTypeEXT::eSurfaceKhr: return "SurfaceKhr";\r
+ case DebugReportObjectTypeEXT::eSwapchainKhr: return "SwapchainKhr";\r
+ case DebugReportObjectTypeEXT::eDebugReportCallbackExt: return "DebugReportCallbackExt";\r
+ case DebugReportObjectTypeEXT::eDisplayKhr: return "DisplayKhr";\r
+ case DebugReportObjectTypeEXT::eDisplayModeKhr: return "DisplayModeKhr";\r
+ case DebugReportObjectTypeEXT::eObjectTableNvx: return "ObjectTableNvx";\r
+ case DebugReportObjectTypeEXT::eIndirectCommandsLayoutNvx: return "IndirectCommandsLayoutNvx";\r
+ case DebugReportObjectTypeEXT::eValidationCacheExt: return "ValidationCacheExt";\r
+ case DebugReportObjectTypeEXT::eSamplerYcbcrConversion: return "SamplerYcbcrConversion";\r
+ case DebugReportObjectTypeEXT::eDescriptorUpdateTemplate: return "DescriptorUpdateTemplate";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(RasterizationOrderAMD value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case RasterizationOrderAMD::eStrict: return "Strict";\r
+ case RasterizationOrderAMD::eRelaxed: return "Relaxed";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryHandleTypeFlagBitsNV value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalMemoryHandleTypeFlagBitsNV::eOpaqueWin32: return "OpaqueWin32";\r
+ case ExternalMemoryHandleTypeFlagBitsNV::eOpaqueWin32Kmt: return "OpaqueWin32Kmt";\r
+ case ExternalMemoryHandleTypeFlagBitsNV::eD3D11Image: return "D3D11Image";\r
+ case ExternalMemoryHandleTypeFlagBitsNV::eD3D11ImageKmt: return "D3D11ImageKmt";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryHandleTypeFlagsNV value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalMemoryHandleTypeFlagBitsNV::eOpaqueWin32) result += "OpaqueWin32 | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBitsNV::eOpaqueWin32Kmt) result += "OpaqueWin32Kmt | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBitsNV::eD3D11Image) result += "D3D11Image | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBitsNV::eD3D11ImageKmt) result += "D3D11ImageKmt | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryFeatureFlagBitsNV value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalMemoryFeatureFlagBitsNV::eDedicatedOnly: return "DedicatedOnly";\r
+ case ExternalMemoryFeatureFlagBitsNV::eExportable: return "Exportable";\r
+ case ExternalMemoryFeatureFlagBitsNV::eImportable: return "Importable";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryFeatureFlagsNV value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalMemoryFeatureFlagBitsNV::eDedicatedOnly) result += "DedicatedOnly | ";\r
+ if (value & ExternalMemoryFeatureFlagBitsNV::eExportable) result += "Exportable | ";\r
+ if (value & ExternalMemoryFeatureFlagBitsNV::eImportable) result += "Importable | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ValidationCheckEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ValidationCheckEXT::eAll: return "All";\r
+ case ValidationCheckEXT::eShaders: return "Shaders";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SubgroupFeatureFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SubgroupFeatureFlagBits::eBasic: return "Basic";\r
+ case SubgroupFeatureFlagBits::eVote: return "Vote";\r
+ case SubgroupFeatureFlagBits::eArithmetic: return "Arithmetic";\r
+ case SubgroupFeatureFlagBits::eBallot: return "Ballot";\r
+ case SubgroupFeatureFlagBits::eShuffle: return "Shuffle";\r
+ case SubgroupFeatureFlagBits::eShuffleRelative: return "ShuffleRelative";\r
+ case SubgroupFeatureFlagBits::eClustered: return "Clustered";\r
+ case SubgroupFeatureFlagBits::eQuad: return "Quad";\r
+ case SubgroupFeatureFlagBits::ePartitionedNV: return "PartitionedNV";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SubgroupFeatureFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SubgroupFeatureFlagBits::eBasic) result += "Basic | ";\r
+ if (value & SubgroupFeatureFlagBits::eVote) result += "Vote | ";\r
+ if (value & SubgroupFeatureFlagBits::eArithmetic) result += "Arithmetic | ";\r
+ if (value & SubgroupFeatureFlagBits::eBallot) result += "Ballot | ";\r
+ if (value & SubgroupFeatureFlagBits::eShuffle) result += "Shuffle | ";\r
+ if (value & SubgroupFeatureFlagBits::eShuffleRelative) result += "ShuffleRelative | ";\r
+ if (value & SubgroupFeatureFlagBits::eClustered) result += "Clustered | ";\r
+ if (value & SubgroupFeatureFlagBits::eQuad) result += "Quad | ";\r
+ if (value & SubgroupFeatureFlagBits::ePartitionedNV) result += "PartitionedNV | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(IndirectCommandsLayoutUsageFlagBitsNVX value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case IndirectCommandsLayoutUsageFlagBitsNVX::eUnorderedSequences: return "UnorderedSequences";\r
+ case IndirectCommandsLayoutUsageFlagBitsNVX::eSparseSequences: return "SparseSequences";\r
+ case IndirectCommandsLayoutUsageFlagBitsNVX::eEmptyExecutions: return "EmptyExecutions";\r
+ case IndirectCommandsLayoutUsageFlagBitsNVX::eIndexedSequences: return "IndexedSequences";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(IndirectCommandsLayoutUsageFlagsNVX value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & IndirectCommandsLayoutUsageFlagBitsNVX::eUnorderedSequences) result += "UnorderedSequences | ";\r
+ if (value & IndirectCommandsLayoutUsageFlagBitsNVX::eSparseSequences) result += "SparseSequences | ";\r
+ if (value & IndirectCommandsLayoutUsageFlagBitsNVX::eEmptyExecutions) result += "EmptyExecutions | ";\r
+ if (value & IndirectCommandsLayoutUsageFlagBitsNVX::eIndexedSequences) result += "IndexedSequences | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ObjectEntryUsageFlagBitsNVX value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ObjectEntryUsageFlagBitsNVX::eGraphics: return "Graphics";\r
+ case ObjectEntryUsageFlagBitsNVX::eCompute: return "Compute";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ObjectEntryUsageFlagsNVX value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ObjectEntryUsageFlagBitsNVX::eGraphics) result += "Graphics | ";\r
+ if (value & ObjectEntryUsageFlagBitsNVX::eCompute) result += "Compute | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(IndirectCommandsTokenTypeNVX value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case IndirectCommandsTokenTypeNVX::ePipeline: return "Pipeline";\r
+ case IndirectCommandsTokenTypeNVX::eDescriptorSet: return "DescriptorSet";\r
+ case IndirectCommandsTokenTypeNVX::eIndexBuffer: return "IndexBuffer";\r
+ case IndirectCommandsTokenTypeNVX::eVertexBuffer: return "VertexBuffer";\r
+ case IndirectCommandsTokenTypeNVX::ePushConstant: return "PushConstant";\r
+ case IndirectCommandsTokenTypeNVX::eDrawIndexed: return "DrawIndexed";\r
+ case IndirectCommandsTokenTypeNVX::eDraw: return "Draw";\r
+ case IndirectCommandsTokenTypeNVX::eDispatch: return "Dispatch";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ObjectEntryTypeNVX value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ObjectEntryTypeNVX::eDescriptorSet: return "DescriptorSet";\r
+ case ObjectEntryTypeNVX::ePipeline: return "Pipeline";\r
+ case ObjectEntryTypeNVX::eIndexBuffer: return "IndexBuffer";\r
+ case ObjectEntryTypeNVX::eVertexBuffer: return "VertexBuffer";\r
+ case ObjectEntryTypeNVX::ePushConstant: return "PushConstant";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorSetLayoutCreateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DescriptorSetLayoutCreateFlagBits::ePushDescriptorKHR: return "PushDescriptorKHR";\r
+ case DescriptorSetLayoutCreateFlagBits::eUpdateAfterBindPoolEXT: return "UpdateAfterBindPoolEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorSetLayoutCreateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DescriptorSetLayoutCreateFlagBits::ePushDescriptorKHR) result += "PushDescriptorKHR | ";\r
+ if (value & DescriptorSetLayoutCreateFlagBits::eUpdateAfterBindPoolEXT) result += "UpdateAfterBindPoolEXT | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryHandleTypeFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalMemoryHandleTypeFlagBits::eOpaqueFd: return "OpaqueFd";\r
+ case ExternalMemoryHandleTypeFlagBits::eOpaqueWin32: return "OpaqueWin32";\r
+ case ExternalMemoryHandleTypeFlagBits::eOpaqueWin32Kmt: return "OpaqueWin32Kmt";\r
+ case ExternalMemoryHandleTypeFlagBits::eD3D11Texture: return "D3D11Texture";\r
+ case ExternalMemoryHandleTypeFlagBits::eD3D11TextureKmt: return "D3D11TextureKmt";\r
+ case ExternalMemoryHandleTypeFlagBits::eD3D12Heap: return "D3D12Heap";\r
+ case ExternalMemoryHandleTypeFlagBits::eD3D12Resource: return "D3D12Resource";\r
+ case ExternalMemoryHandleTypeFlagBits::eDmaBufEXT: return "DmaBufEXT";\r
+ case ExternalMemoryHandleTypeFlagBits::eAndroidHardwareBufferANDROID: return "AndroidHardwareBufferANDROID";\r
+ case ExternalMemoryHandleTypeFlagBits::eHostAllocationEXT: return "HostAllocationEXT";\r
+ case ExternalMemoryHandleTypeFlagBits::eHostMappedForeignMemoryEXT: return "HostMappedForeignMemoryEXT";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryHandleTypeFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eOpaqueFd) result += "OpaqueFd | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eOpaqueWin32) result += "OpaqueWin32 | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eOpaqueWin32Kmt) result += "OpaqueWin32Kmt | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eD3D11Texture) result += "D3D11Texture | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eD3D11TextureKmt) result += "D3D11TextureKmt | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eD3D12Heap) result += "D3D12Heap | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eD3D12Resource) result += "D3D12Resource | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eDmaBufEXT) result += "DmaBufEXT | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eAndroidHardwareBufferANDROID) result += "AndroidHardwareBufferANDROID | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eHostAllocationEXT) result += "HostAllocationEXT | ";\r
+ if (value & ExternalMemoryHandleTypeFlagBits::eHostMappedForeignMemoryEXT) result += "HostMappedForeignMemoryEXT | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryFeatureFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalMemoryFeatureFlagBits::eDedicatedOnly: return "DedicatedOnly";\r
+ case ExternalMemoryFeatureFlagBits::eExportable: return "Exportable";\r
+ case ExternalMemoryFeatureFlagBits::eImportable: return "Importable";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalMemoryFeatureFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalMemoryFeatureFlagBits::eDedicatedOnly) result += "DedicatedOnly | ";\r
+ if (value & ExternalMemoryFeatureFlagBits::eExportable) result += "Exportable | ";\r
+ if (value & ExternalMemoryFeatureFlagBits::eImportable) result += "Importable | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalSemaphoreHandleTypeFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd: return "OpaqueFd";\r
+ case ExternalSemaphoreHandleTypeFlagBits::eOpaqueWin32: return "OpaqueWin32";\r
+ case ExternalSemaphoreHandleTypeFlagBits::eOpaqueWin32Kmt: return "OpaqueWin32Kmt";\r
+ case ExternalSemaphoreHandleTypeFlagBits::eD3D12Fence: return "D3D12Fence";\r
+ case ExternalSemaphoreHandleTypeFlagBits::eSyncFd: return "SyncFd";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalSemaphoreHandleTypeFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalSemaphoreHandleTypeFlagBits::eOpaqueFd) result += "OpaqueFd | ";\r
+ if (value & ExternalSemaphoreHandleTypeFlagBits::eOpaqueWin32) result += "OpaqueWin32 | ";\r
+ if (value & ExternalSemaphoreHandleTypeFlagBits::eOpaqueWin32Kmt) result += "OpaqueWin32Kmt | ";\r
+ if (value & ExternalSemaphoreHandleTypeFlagBits::eD3D12Fence) result += "D3D12Fence | ";\r
+ if (value & ExternalSemaphoreHandleTypeFlagBits::eSyncFd) result += "SyncFd | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalSemaphoreFeatureFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalSemaphoreFeatureFlagBits::eExportable: return "Exportable";\r
+ case ExternalSemaphoreFeatureFlagBits::eImportable: return "Importable";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalSemaphoreFeatureFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalSemaphoreFeatureFlagBits::eExportable) result += "Exportable | ";\r
+ if (value & ExternalSemaphoreFeatureFlagBits::eImportable) result += "Importable | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SemaphoreImportFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SemaphoreImportFlagBits::eTemporary: return "Temporary";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SemaphoreImportFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SemaphoreImportFlagBits::eTemporary) result += "Temporary | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalFenceHandleTypeFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalFenceHandleTypeFlagBits::eOpaqueFd: return "OpaqueFd";\r
+ case ExternalFenceHandleTypeFlagBits::eOpaqueWin32: return "OpaqueWin32";\r
+ case ExternalFenceHandleTypeFlagBits::eOpaqueWin32Kmt: return "OpaqueWin32Kmt";\r
+ case ExternalFenceHandleTypeFlagBits::eSyncFd: return "SyncFd";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalFenceHandleTypeFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalFenceHandleTypeFlagBits::eOpaqueFd) result += "OpaqueFd | ";\r
+ if (value & ExternalFenceHandleTypeFlagBits::eOpaqueWin32) result += "OpaqueWin32 | ";\r
+ if (value & ExternalFenceHandleTypeFlagBits::eOpaqueWin32Kmt) result += "OpaqueWin32Kmt | ";\r
+ if (value & ExternalFenceHandleTypeFlagBits::eSyncFd) result += "SyncFd | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalFenceFeatureFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ExternalFenceFeatureFlagBits::eExportable: return "Exportable";\r
+ case ExternalFenceFeatureFlagBits::eImportable: return "Importable";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ExternalFenceFeatureFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & ExternalFenceFeatureFlagBits::eExportable) result += "Exportable | ";\r
+ if (value & ExternalFenceFeatureFlagBits::eImportable) result += "Importable | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FenceImportFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case FenceImportFlagBits::eTemporary: return "Temporary";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(FenceImportFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & FenceImportFlagBits::eTemporary) result += "Temporary | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SurfaceCounterFlagBitsEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SurfaceCounterFlagBitsEXT::eVblank: return "Vblank";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SurfaceCounterFlagsEXT value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SurfaceCounterFlagBitsEXT::eVblank) result += "Vblank | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplayPowerStateEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DisplayPowerStateEXT::eOff: return "Off";\r
+ case DisplayPowerStateEXT::eSuspend: return "Suspend";\r
+ case DisplayPowerStateEXT::eOn: return "On";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceEventTypeEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DeviceEventTypeEXT::eDisplayHotplug: return "DisplayHotplug";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DisplayEventTypeEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DisplayEventTypeEXT::eFirstPixelOut: return "FirstPixelOut";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PeerMemoryFeatureFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PeerMemoryFeatureFlagBits::eCopySrc: return "CopySrc";\r
+ case PeerMemoryFeatureFlagBits::eCopyDst: return "CopyDst";\r
+ case PeerMemoryFeatureFlagBits::eGenericSrc: return "GenericSrc";\r
+ case PeerMemoryFeatureFlagBits::eGenericDst: return "GenericDst";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PeerMemoryFeatureFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & PeerMemoryFeatureFlagBits::eCopySrc) result += "CopySrc | ";\r
+ if (value & PeerMemoryFeatureFlagBits::eCopyDst) result += "CopyDst | ";\r
+ if (value & PeerMemoryFeatureFlagBits::eGenericSrc) result += "GenericSrc | ";\r
+ if (value & PeerMemoryFeatureFlagBits::eGenericDst) result += "GenericDst | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryAllocateFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case MemoryAllocateFlagBits::eDeviceMask: return "DeviceMask";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(MemoryAllocateFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & MemoryAllocateFlagBits::eDeviceMask) result += "DeviceMask | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceGroupPresentModeFlagBitsKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DeviceGroupPresentModeFlagBitsKHR::eLocal: return "Local";\r
+ case DeviceGroupPresentModeFlagBitsKHR::eRemote: return "Remote";\r
+ case DeviceGroupPresentModeFlagBitsKHR::eSum: return "Sum";\r
+ case DeviceGroupPresentModeFlagBitsKHR::eLocalMultiDevice: return "LocalMultiDevice";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DeviceGroupPresentModeFlagsKHR value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DeviceGroupPresentModeFlagBitsKHR::eLocal) result += "Local | ";\r
+ if (value & DeviceGroupPresentModeFlagBitsKHR::eRemote) result += "Remote | ";\r
+ if (value & DeviceGroupPresentModeFlagBitsKHR::eSum) result += "Sum | ";\r
+ if (value & DeviceGroupPresentModeFlagBitsKHR::eLocalMultiDevice) result += "LocalMultiDevice | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SwapchainCreateFlagBitsKHR value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SwapchainCreateFlagBitsKHR::eSplitInstanceBindRegions: return "SplitInstanceBindRegions";\r
+ case SwapchainCreateFlagBitsKHR::eProtected: return "Protected";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SwapchainCreateFlagsKHR value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SwapchainCreateFlagBitsKHR::eSplitInstanceBindRegions) result += "SplitInstanceBindRegions | ";\r
+ if (value & SwapchainCreateFlagBitsKHR::eProtected) result += "Protected | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ViewportCoordinateSwizzleNV value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ViewportCoordinateSwizzleNV::ePositiveX: return "PositiveX";\r
+ case ViewportCoordinateSwizzleNV::eNegativeX: return "NegativeX";\r
+ case ViewportCoordinateSwizzleNV::ePositiveY: return "PositiveY";\r
+ case ViewportCoordinateSwizzleNV::eNegativeY: return "NegativeY";\r
+ case ViewportCoordinateSwizzleNV::ePositiveZ: return "PositiveZ";\r
+ case ViewportCoordinateSwizzleNV::eNegativeZ: return "NegativeZ";\r
+ case ViewportCoordinateSwizzleNV::ePositiveW: return "PositiveW";\r
+ case ViewportCoordinateSwizzleNV::eNegativeW: return "NegativeW";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DiscardRectangleModeEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DiscardRectangleModeEXT::eInclusive: return "Inclusive";\r
+ case DiscardRectangleModeEXT::eExclusive: return "Exclusive";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SubpassDescriptionFlagBits value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SubpassDescriptionFlagBits::ePerViewAttributesNVX: return "PerViewAttributesNVX";\r
+ case SubpassDescriptionFlagBits::ePerViewPositionXOnlyNVX: return "PerViewPositionXOnlyNVX";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SubpassDescriptionFlags value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & SubpassDescriptionFlagBits::ePerViewAttributesNVX) result += "PerViewAttributesNVX | ";\r
+ if (value & SubpassDescriptionFlagBits::ePerViewPositionXOnlyNVX) result += "PerViewPositionXOnlyNVX | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(PointClippingBehavior value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case PointClippingBehavior::eAllClipPlanes: return "AllClipPlanes";\r
+ case PointClippingBehavior::eUserClipPlanesOnly: return "UserClipPlanesOnly";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerReductionModeEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SamplerReductionModeEXT::eWeightedAverage: return "WeightedAverage";\r
+ case SamplerReductionModeEXT::eMin: return "Min";\r
+ case SamplerReductionModeEXT::eMax: return "Max";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(TessellationDomainOrigin value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case TessellationDomainOrigin::eUpperLeft: return "UpperLeft";\r
+ case TessellationDomainOrigin::eLowerLeft: return "LowerLeft";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerYcbcrModelConversion value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SamplerYcbcrModelConversion::eRgbIdentity: return "RgbIdentity";\r
+ case SamplerYcbcrModelConversion::eYcbcrIdentity: return "YcbcrIdentity";\r
+ case SamplerYcbcrModelConversion::eYcbcr709: return "Ycbcr709";\r
+ case SamplerYcbcrModelConversion::eYcbcr601: return "Ycbcr601";\r
+ case SamplerYcbcrModelConversion::eYcbcr2020: return "Ycbcr2020";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(SamplerYcbcrRange value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case SamplerYcbcrRange::eItuFull: return "ItuFull";\r
+ case SamplerYcbcrRange::eItuNarrow: return "ItuNarrow";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ChromaLocation value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ChromaLocation::eCositedEven: return "CositedEven";\r
+ case ChromaLocation::eMidpoint: return "Midpoint";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(BlendOverlapEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case BlendOverlapEXT::eUncorrelated: return "Uncorrelated";\r
+ case BlendOverlapEXT::eDisjoint: return "Disjoint";\r
+ case BlendOverlapEXT::eConjoint: return "Conjoint";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(CoverageModulationModeNV value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case CoverageModulationModeNV::eNone: return "None";\r
+ case CoverageModulationModeNV::eRgb: return "Rgb";\r
+ case CoverageModulationModeNV::eAlpha: return "Alpha";\r
+ case CoverageModulationModeNV::eRgba: return "Rgba";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ValidationCacheHeaderVersionEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ValidationCacheHeaderVersionEXT::eOne: return "One";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ShaderInfoTypeAMD value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ShaderInfoTypeAMD::eStatistics: return "Statistics";\r
+ case ShaderInfoTypeAMD::eBinary: return "Binary";\r
+ case ShaderInfoTypeAMD::eDisassembly: return "Disassembly";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(QueueGlobalPriorityEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case QueueGlobalPriorityEXT::eLow: return "Low";\r
+ case QueueGlobalPriorityEXT::eMedium: return "Medium";\r
+ case QueueGlobalPriorityEXT::eHigh: return "High";\r
+ case QueueGlobalPriorityEXT::eRealtime: return "Realtime";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessageSeverityFlagBitsEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DebugUtilsMessageSeverityFlagBitsEXT::eVerbose: return "Verbose";\r
+ case DebugUtilsMessageSeverityFlagBitsEXT::eInfo: return "Info";\r
+ case DebugUtilsMessageSeverityFlagBitsEXT::eWarning: return "Warning";\r
+ case DebugUtilsMessageSeverityFlagBitsEXT::eError: return "Error";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessageSeverityFlagsEXT value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DebugUtilsMessageSeverityFlagBitsEXT::eVerbose) result += "Verbose | ";\r
+ if (value & DebugUtilsMessageSeverityFlagBitsEXT::eInfo) result += "Info | ";\r
+ if (value & DebugUtilsMessageSeverityFlagBitsEXT::eWarning) result += "Warning | ";\r
+ if (value & DebugUtilsMessageSeverityFlagBitsEXT::eError) result += "Error | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessageTypeFlagBitsEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DebugUtilsMessageTypeFlagBitsEXT::eGeneral: return "General";\r
+ case DebugUtilsMessageTypeFlagBitsEXT::eValidation: return "Validation";\r
+ case DebugUtilsMessageTypeFlagBitsEXT::ePerformance: return "Performance";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DebugUtilsMessageTypeFlagsEXT value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DebugUtilsMessageTypeFlagBitsEXT::eGeneral) result += "General | ";\r
+ if (value & DebugUtilsMessageTypeFlagBitsEXT::eValidation) result += "Validation | ";\r
+ if (value & DebugUtilsMessageTypeFlagBitsEXT::ePerformance) result += "Performance | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(ConservativeRasterizationModeEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case ConservativeRasterizationModeEXT::eDisabled: return "Disabled";\r
+ case ConservativeRasterizationModeEXT::eOverestimate: return "Overestimate";\r
+ case ConservativeRasterizationModeEXT::eUnderestimate: return "Underestimate";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorBindingFlagBitsEXT value)\r
+ {\r
+ switch (value)\r
+ {\r
+ case DescriptorBindingFlagBitsEXT::eUpdateAfterBind: return "UpdateAfterBind";\r
+ case DescriptorBindingFlagBitsEXT::eUpdateUnusedWhilePending: return "UpdateUnusedWhilePending";\r
+ case DescriptorBindingFlagBitsEXT::ePartiallyBound: return "PartiallyBound";\r
+ case DescriptorBindingFlagBitsEXT::eVariableDescriptorCount: return "VariableDescriptorCount";\r
+ default: return "invalid";\r
+ }\r
+ }\r
+\r
+ VULKAN_HPP_INLINE std::string to_string(DescriptorBindingFlagsEXT value)\r
+ {\r
+ if (!value) return "{}";\r
+ std::string result;\r
+ if (value & DescriptorBindingFlagBitsEXT::eUpdateAfterBind) result += "UpdateAfterBind | ";\r
+ if (value & DescriptorBindingFlagBitsEXT::eUpdateUnusedWhilePending) result += "UpdateUnusedWhilePending | ";\r
+ if (value & DescriptorBindingFlagBitsEXT::ePartiallyBound) result += "PartiallyBound | ";\r
+ if (value & DescriptorBindingFlagBitsEXT::eVariableDescriptorCount) result += "VariableDescriptorCount | ";\r
+ return "{" + result.substr(0, result.size() - 3) + "}";\r
+ }\r
+\r
+ class DispatchLoaderDynamic\r
+ {\r
+ public:\r
+ PFN_vkAcquireNextImage2KHR vkAcquireNextImage2KHR = 0;\r
+ PFN_vkAcquireNextImageKHR vkAcquireNextImageKHR = 0;\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ PFN_vkAcquireXlibDisplayEXT vkAcquireXlibDisplayEXT = 0;\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+ PFN_vkAllocateCommandBuffers vkAllocateCommandBuffers = 0;\r
+ PFN_vkAllocateDescriptorSets vkAllocateDescriptorSets = 0;\r
+ PFN_vkAllocateMemory vkAllocateMemory = 0;\r
+ PFN_vkBeginCommandBuffer vkBeginCommandBuffer = 0;\r
+ PFN_vkBindBufferMemory vkBindBufferMemory = 0;\r
+ PFN_vkBindBufferMemory2 vkBindBufferMemory2 = 0;\r
+ PFN_vkBindBufferMemory2KHR vkBindBufferMemory2KHR = 0;\r
+ PFN_vkBindImageMemory vkBindImageMemory = 0;\r
+ PFN_vkBindImageMemory2 vkBindImageMemory2 = 0;\r
+ PFN_vkBindImageMemory2KHR vkBindImageMemory2KHR = 0;\r
+ PFN_vkCmdBeginDebugUtilsLabelEXT vkCmdBeginDebugUtilsLabelEXT = 0;\r
+ PFN_vkCmdBeginQuery vkCmdBeginQuery = 0;\r
+ PFN_vkCmdBeginRenderPass vkCmdBeginRenderPass = 0;\r
+ PFN_vkCmdBindDescriptorSets vkCmdBindDescriptorSets = 0;\r
+ PFN_vkCmdBindIndexBuffer vkCmdBindIndexBuffer = 0;\r
+ PFN_vkCmdBindPipeline vkCmdBindPipeline = 0;\r
+ PFN_vkCmdBindVertexBuffers vkCmdBindVertexBuffers = 0;\r
+ PFN_vkCmdBlitImage vkCmdBlitImage = 0;\r
+ PFN_vkCmdClearAttachments vkCmdClearAttachments = 0;\r
+ PFN_vkCmdClearColorImage vkCmdClearColorImage = 0;\r
+ PFN_vkCmdClearDepthStencilImage vkCmdClearDepthStencilImage = 0;\r
+ PFN_vkCmdCopyBuffer vkCmdCopyBuffer = 0;\r
+ PFN_vkCmdCopyBufferToImage vkCmdCopyBufferToImage = 0;\r
+ PFN_vkCmdCopyImage vkCmdCopyImage = 0;\r
+ PFN_vkCmdCopyImageToBuffer vkCmdCopyImageToBuffer = 0;\r
+ PFN_vkCmdCopyQueryPoolResults vkCmdCopyQueryPoolResults = 0;\r
+ PFN_vkCmdDebugMarkerBeginEXT vkCmdDebugMarkerBeginEXT = 0;\r
+ PFN_vkCmdDebugMarkerEndEXT vkCmdDebugMarkerEndEXT = 0;\r
+ PFN_vkCmdDebugMarkerInsertEXT vkCmdDebugMarkerInsertEXT = 0;\r
+ PFN_vkCmdDispatch vkCmdDispatch = 0;\r
+ PFN_vkCmdDispatchBase vkCmdDispatchBase = 0;\r
+ PFN_vkCmdDispatchBaseKHR vkCmdDispatchBaseKHR = 0;\r
+ PFN_vkCmdDispatchIndirect vkCmdDispatchIndirect = 0;\r
+ PFN_vkCmdDraw vkCmdDraw = 0;\r
+ PFN_vkCmdDrawIndexed vkCmdDrawIndexed = 0;\r
+ PFN_vkCmdDrawIndexedIndirect vkCmdDrawIndexedIndirect = 0;\r
+ PFN_vkCmdDrawIndexedIndirectCountAMD vkCmdDrawIndexedIndirectCountAMD = 0;\r
+ PFN_vkCmdDrawIndirect vkCmdDrawIndirect = 0;\r
+ PFN_vkCmdDrawIndirectCountAMD vkCmdDrawIndirectCountAMD = 0;\r
+ PFN_vkCmdEndDebugUtilsLabelEXT vkCmdEndDebugUtilsLabelEXT = 0;\r
+ PFN_vkCmdEndQuery vkCmdEndQuery = 0;\r
+ PFN_vkCmdEndRenderPass vkCmdEndRenderPass = 0;\r
+ PFN_vkCmdExecuteCommands vkCmdExecuteCommands = 0;\r
+ PFN_vkCmdFillBuffer vkCmdFillBuffer = 0;\r
+ PFN_vkCmdInsertDebugUtilsLabelEXT vkCmdInsertDebugUtilsLabelEXT = 0;\r
+ PFN_vkCmdNextSubpass vkCmdNextSubpass = 0;\r
+ PFN_vkCmdPipelineBarrier vkCmdPipelineBarrier = 0;\r
+ PFN_vkCmdProcessCommandsNVX vkCmdProcessCommandsNVX = 0;\r
+ PFN_vkCmdPushConstants vkCmdPushConstants = 0;\r
+ PFN_vkCmdPushDescriptorSetKHR vkCmdPushDescriptorSetKHR = 0;\r
+ PFN_vkCmdPushDescriptorSetWithTemplateKHR vkCmdPushDescriptorSetWithTemplateKHR = 0;\r
+ PFN_vkCmdReserveSpaceForCommandsNVX vkCmdReserveSpaceForCommandsNVX = 0;\r
+ PFN_vkCmdResetEvent vkCmdResetEvent = 0;\r
+ PFN_vkCmdResetQueryPool vkCmdResetQueryPool = 0;\r
+ PFN_vkCmdResolveImage vkCmdResolveImage = 0;\r
+ PFN_vkCmdSetBlendConstants vkCmdSetBlendConstants = 0;\r
+ PFN_vkCmdSetDepthBias vkCmdSetDepthBias = 0;\r
+ PFN_vkCmdSetDepthBounds vkCmdSetDepthBounds = 0;\r
+ PFN_vkCmdSetDeviceMask vkCmdSetDeviceMask = 0;\r
+ PFN_vkCmdSetDeviceMaskKHR vkCmdSetDeviceMaskKHR = 0;\r
+ PFN_vkCmdSetDiscardRectangleEXT vkCmdSetDiscardRectangleEXT = 0;\r
+ PFN_vkCmdSetEvent vkCmdSetEvent = 0;\r
+ PFN_vkCmdSetLineWidth vkCmdSetLineWidth = 0;\r
+ PFN_vkCmdSetSampleLocationsEXT vkCmdSetSampleLocationsEXT = 0;\r
+ PFN_vkCmdSetScissor vkCmdSetScissor = 0;\r
+ PFN_vkCmdSetStencilCompareMask vkCmdSetStencilCompareMask = 0;\r
+ PFN_vkCmdSetStencilReference vkCmdSetStencilReference = 0;\r
+ PFN_vkCmdSetStencilWriteMask vkCmdSetStencilWriteMask = 0;\r
+ PFN_vkCmdSetViewport vkCmdSetViewport = 0;\r
+ PFN_vkCmdSetViewportWScalingNV vkCmdSetViewportWScalingNV = 0;\r
+ PFN_vkCmdUpdateBuffer vkCmdUpdateBuffer = 0;\r
+ PFN_vkCmdWaitEvents vkCmdWaitEvents = 0;\r
+ PFN_vkCmdWriteBufferMarkerAMD vkCmdWriteBufferMarkerAMD = 0;\r
+ PFN_vkCmdWriteTimestamp vkCmdWriteTimestamp = 0;\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ PFN_vkCreateAndroidSurfaceKHR vkCreateAndroidSurfaceKHR = 0;\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+ PFN_vkCreateBuffer vkCreateBuffer = 0;\r
+ PFN_vkCreateBufferView vkCreateBufferView = 0;\r
+ PFN_vkCreateCommandPool vkCreateCommandPool = 0;\r
+ PFN_vkCreateComputePipelines vkCreateComputePipelines = 0;\r
+ PFN_vkCreateDebugReportCallbackEXT vkCreateDebugReportCallbackEXT = 0;\r
+ PFN_vkCreateDebugUtilsMessengerEXT vkCreateDebugUtilsMessengerEXT = 0;\r
+ PFN_vkCreateDescriptorPool vkCreateDescriptorPool = 0;\r
+ PFN_vkCreateDescriptorSetLayout vkCreateDescriptorSetLayout = 0;\r
+ PFN_vkCreateDescriptorUpdateTemplate vkCreateDescriptorUpdateTemplate = 0;\r
+ PFN_vkCreateDescriptorUpdateTemplateKHR vkCreateDescriptorUpdateTemplateKHR = 0;\r
+ PFN_vkCreateDevice vkCreateDevice = 0;\r
+ PFN_vkCreateDisplayModeKHR vkCreateDisplayModeKHR = 0;\r
+ PFN_vkCreateDisplayPlaneSurfaceKHR vkCreateDisplayPlaneSurfaceKHR = 0;\r
+ PFN_vkCreateEvent vkCreateEvent = 0;\r
+ PFN_vkCreateFence vkCreateFence = 0;\r
+ PFN_vkCreateFramebuffer vkCreateFramebuffer = 0;\r
+ PFN_vkCreateGraphicsPipelines vkCreateGraphicsPipelines = 0;\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ PFN_vkCreateIOSSurfaceMVK vkCreateIOSSurfaceMVK = 0;\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+ PFN_vkCreateImage vkCreateImage = 0;\r
+ PFN_vkCreateImageView vkCreateImageView = 0;\r
+ PFN_vkCreateIndirectCommandsLayoutNVX vkCreateIndirectCommandsLayoutNVX = 0;\r
+ PFN_vkCreateInstance vkCreateInstance = 0;\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ PFN_vkCreateMacOSSurfaceMVK vkCreateMacOSSurfaceMVK = 0;\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ PFN_vkCreateMirSurfaceKHR vkCreateMirSurfaceKHR = 0;\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+ PFN_vkCreateObjectTableNVX vkCreateObjectTableNVX = 0;\r
+ PFN_vkCreatePipelineCache vkCreatePipelineCache = 0;\r
+ PFN_vkCreatePipelineLayout vkCreatePipelineLayout = 0;\r
+ PFN_vkCreateQueryPool vkCreateQueryPool = 0;\r
+ PFN_vkCreateRenderPass vkCreateRenderPass = 0;\r
+ PFN_vkCreateSampler vkCreateSampler = 0;\r
+ PFN_vkCreateSamplerYcbcrConversion vkCreateSamplerYcbcrConversion = 0;\r
+ PFN_vkCreateSamplerYcbcrConversionKHR vkCreateSamplerYcbcrConversionKHR = 0;\r
+ PFN_vkCreateSemaphore vkCreateSemaphore = 0;\r
+ PFN_vkCreateShaderModule vkCreateShaderModule = 0;\r
+ PFN_vkCreateSharedSwapchainsKHR vkCreateSharedSwapchainsKHR = 0;\r
+ PFN_vkCreateSwapchainKHR vkCreateSwapchainKHR = 0;\r
+ PFN_vkCreateValidationCacheEXT vkCreateValidationCacheEXT = 0;\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ PFN_vkCreateViSurfaceNN vkCreateViSurfaceNN = 0;\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ PFN_vkCreateWaylandSurfaceKHR vkCreateWaylandSurfaceKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkCreateWin32SurfaceKHR vkCreateWin32SurfaceKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ PFN_vkCreateXcbSurfaceKHR vkCreateXcbSurfaceKHR = 0;\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ PFN_vkCreateXlibSurfaceKHR vkCreateXlibSurfaceKHR = 0;\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+ PFN_vkDebugMarkerSetObjectNameEXT vkDebugMarkerSetObjectNameEXT = 0;\r
+ PFN_vkDebugMarkerSetObjectTagEXT vkDebugMarkerSetObjectTagEXT = 0;\r
+ PFN_vkDebugReportMessageEXT vkDebugReportMessageEXT = 0;\r
+ PFN_vkDestroyBuffer vkDestroyBuffer = 0;\r
+ PFN_vkDestroyBufferView vkDestroyBufferView = 0;\r
+ PFN_vkDestroyCommandPool vkDestroyCommandPool = 0;\r
+ PFN_vkDestroyDebugReportCallbackEXT vkDestroyDebugReportCallbackEXT = 0;\r
+ PFN_vkDestroyDebugUtilsMessengerEXT vkDestroyDebugUtilsMessengerEXT = 0;\r
+ PFN_vkDestroyDescriptorPool vkDestroyDescriptorPool = 0;\r
+ PFN_vkDestroyDescriptorSetLayout vkDestroyDescriptorSetLayout = 0;\r
+ PFN_vkDestroyDescriptorUpdateTemplate vkDestroyDescriptorUpdateTemplate = 0;\r
+ PFN_vkDestroyDescriptorUpdateTemplateKHR vkDestroyDescriptorUpdateTemplateKHR = 0;\r
+ PFN_vkDestroyDevice vkDestroyDevice = 0;\r
+ PFN_vkDestroyEvent vkDestroyEvent = 0;\r
+ PFN_vkDestroyFence vkDestroyFence = 0;\r
+ PFN_vkDestroyFramebuffer vkDestroyFramebuffer = 0;\r
+ PFN_vkDestroyImage vkDestroyImage = 0;\r
+ PFN_vkDestroyImageView vkDestroyImageView = 0;\r
+ PFN_vkDestroyIndirectCommandsLayoutNVX vkDestroyIndirectCommandsLayoutNVX = 0;\r
+ PFN_vkDestroyInstance vkDestroyInstance = 0;\r
+ PFN_vkDestroyObjectTableNVX vkDestroyObjectTableNVX = 0;\r
+ PFN_vkDestroyPipeline vkDestroyPipeline = 0;\r
+ PFN_vkDestroyPipelineCache vkDestroyPipelineCache = 0;\r
+ PFN_vkDestroyPipelineLayout vkDestroyPipelineLayout = 0;\r
+ PFN_vkDestroyQueryPool vkDestroyQueryPool = 0;\r
+ PFN_vkDestroyRenderPass vkDestroyRenderPass = 0;\r
+ PFN_vkDestroySampler vkDestroySampler = 0;\r
+ PFN_vkDestroySamplerYcbcrConversion vkDestroySamplerYcbcrConversion = 0;\r
+ PFN_vkDestroySamplerYcbcrConversionKHR vkDestroySamplerYcbcrConversionKHR = 0;\r
+ PFN_vkDestroySemaphore vkDestroySemaphore = 0;\r
+ PFN_vkDestroyShaderModule vkDestroyShaderModule = 0;\r
+ PFN_vkDestroySurfaceKHR vkDestroySurfaceKHR = 0;\r
+ PFN_vkDestroySwapchainKHR vkDestroySwapchainKHR = 0;\r
+ PFN_vkDestroyValidationCacheEXT vkDestroyValidationCacheEXT = 0;\r
+ PFN_vkDeviceWaitIdle vkDeviceWaitIdle = 0;\r
+ PFN_vkDisplayPowerControlEXT vkDisplayPowerControlEXT = 0;\r
+ PFN_vkEndCommandBuffer vkEndCommandBuffer = 0;\r
+ PFN_vkEnumerateDeviceExtensionProperties vkEnumerateDeviceExtensionProperties = 0;\r
+ PFN_vkEnumerateDeviceLayerProperties vkEnumerateDeviceLayerProperties = 0;\r
+ PFN_vkEnumerateInstanceExtensionProperties vkEnumerateInstanceExtensionProperties = 0;\r
+ PFN_vkEnumerateInstanceLayerProperties vkEnumerateInstanceLayerProperties = 0;\r
+ PFN_vkEnumerateInstanceVersion vkEnumerateInstanceVersion = 0;\r
+ PFN_vkEnumeratePhysicalDeviceGroups vkEnumeratePhysicalDeviceGroups = 0;\r
+ PFN_vkEnumeratePhysicalDeviceGroupsKHR vkEnumeratePhysicalDeviceGroupsKHR = 0;\r
+ PFN_vkEnumeratePhysicalDevices vkEnumeratePhysicalDevices = 0;\r
+ PFN_vkFlushMappedMemoryRanges vkFlushMappedMemoryRanges = 0;\r
+ PFN_vkFreeCommandBuffers vkFreeCommandBuffers = 0;\r
+ PFN_vkFreeDescriptorSets vkFreeDescriptorSets = 0;\r
+ PFN_vkFreeMemory vkFreeMemory = 0;\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ PFN_vkGetAndroidHardwareBufferPropertiesANDROID vkGetAndroidHardwareBufferPropertiesANDROID = 0;\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ PFN_vkGetBufferMemoryRequirements vkGetBufferMemoryRequirements = 0;\r
+ PFN_vkGetBufferMemoryRequirements2 vkGetBufferMemoryRequirements2 = 0;\r
+ PFN_vkGetBufferMemoryRequirements2KHR vkGetBufferMemoryRequirements2KHR = 0;\r
+ PFN_vkGetDescriptorSetLayoutSupport vkGetDescriptorSetLayoutSupport = 0;\r
+ PFN_vkGetDescriptorSetLayoutSupportKHR vkGetDescriptorSetLayoutSupportKHR = 0;\r
+ PFN_vkGetDeviceGroupPeerMemoryFeatures vkGetDeviceGroupPeerMemoryFeatures = 0;\r
+ PFN_vkGetDeviceGroupPeerMemoryFeaturesKHR vkGetDeviceGroupPeerMemoryFeaturesKHR = 0;\r
+ PFN_vkGetDeviceGroupPresentCapabilitiesKHR vkGetDeviceGroupPresentCapabilitiesKHR = 0;\r
+ PFN_vkGetDeviceGroupSurfacePresentModesKHR vkGetDeviceGroupSurfacePresentModesKHR = 0;\r
+ PFN_vkGetDeviceMemoryCommitment vkGetDeviceMemoryCommitment = 0;\r
+ PFN_vkGetDeviceProcAddr vkGetDeviceProcAddr = 0;\r
+ PFN_vkGetDeviceQueue vkGetDeviceQueue = 0;\r
+ PFN_vkGetDeviceQueue2 vkGetDeviceQueue2 = 0;\r
+ PFN_vkGetDisplayModePropertiesKHR vkGetDisplayModePropertiesKHR = 0;\r
+ PFN_vkGetDisplayPlaneCapabilitiesKHR vkGetDisplayPlaneCapabilitiesKHR = 0;\r
+ PFN_vkGetDisplayPlaneSupportedDisplaysKHR vkGetDisplayPlaneSupportedDisplaysKHR = 0;\r
+ PFN_vkGetEventStatus vkGetEventStatus = 0;\r
+ PFN_vkGetFenceFdKHR vkGetFenceFdKHR = 0;\r
+ PFN_vkGetFenceStatus vkGetFenceStatus = 0;\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkGetFenceWin32HandleKHR vkGetFenceWin32HandleKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ PFN_vkGetImageMemoryRequirements vkGetImageMemoryRequirements = 0;\r
+ PFN_vkGetImageMemoryRequirements2 vkGetImageMemoryRequirements2 = 0;\r
+ PFN_vkGetImageMemoryRequirements2KHR vkGetImageMemoryRequirements2KHR = 0;\r
+ PFN_vkGetImageSparseMemoryRequirements vkGetImageSparseMemoryRequirements = 0;\r
+ PFN_vkGetImageSparseMemoryRequirements2 vkGetImageSparseMemoryRequirements2 = 0;\r
+ PFN_vkGetImageSparseMemoryRequirements2KHR vkGetImageSparseMemoryRequirements2KHR = 0;\r
+ PFN_vkGetImageSubresourceLayout vkGetImageSubresourceLayout = 0;\r
+ PFN_vkGetInstanceProcAddr vkGetInstanceProcAddr = 0;\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ PFN_vkGetMemoryAndroidHardwareBufferANDROID vkGetMemoryAndroidHardwareBufferANDROID = 0;\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ PFN_vkGetMemoryFdKHR vkGetMemoryFdKHR = 0;\r
+ PFN_vkGetMemoryFdPropertiesKHR vkGetMemoryFdPropertiesKHR = 0;\r
+ PFN_vkGetMemoryHostPointerPropertiesEXT vkGetMemoryHostPointerPropertiesEXT = 0;\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkGetMemoryWin32HandleKHR vkGetMemoryWin32HandleKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ PFN_vkGetMemoryWin32HandleNV vkGetMemoryWin32HandleNV = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkGetMemoryWin32HandlePropertiesKHR vkGetMemoryWin32HandlePropertiesKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ PFN_vkGetPastPresentationTimingGOOGLE vkGetPastPresentationTimingGOOGLE = 0;\r
+ PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR vkGetPhysicalDeviceDisplayPlanePropertiesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceDisplayPropertiesKHR vkGetPhysicalDeviceDisplayPropertiesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceExternalBufferProperties vkGetPhysicalDeviceExternalBufferProperties = 0;\r
+ PFN_vkGetPhysicalDeviceExternalBufferPropertiesKHR vkGetPhysicalDeviceExternalBufferPropertiesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceExternalFenceProperties vkGetPhysicalDeviceExternalFenceProperties = 0;\r
+ PFN_vkGetPhysicalDeviceExternalFencePropertiesKHR vkGetPhysicalDeviceExternalFencePropertiesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV vkGetPhysicalDeviceExternalImageFormatPropertiesNV = 0;\r
+ PFN_vkGetPhysicalDeviceExternalSemaphoreProperties vkGetPhysicalDeviceExternalSemaphoreProperties = 0;\r
+ PFN_vkGetPhysicalDeviceExternalSemaphorePropertiesKHR vkGetPhysicalDeviceExternalSemaphorePropertiesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceFeatures vkGetPhysicalDeviceFeatures = 0;\r
+ PFN_vkGetPhysicalDeviceFeatures2 vkGetPhysicalDeviceFeatures2 = 0;\r
+ PFN_vkGetPhysicalDeviceFeatures2KHR vkGetPhysicalDeviceFeatures2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceFormatProperties vkGetPhysicalDeviceFormatProperties = 0;\r
+ PFN_vkGetPhysicalDeviceFormatProperties2 vkGetPhysicalDeviceFormatProperties2 = 0;\r
+ PFN_vkGetPhysicalDeviceFormatProperties2KHR vkGetPhysicalDeviceFormatProperties2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX = 0;\r
+ PFN_vkGetPhysicalDeviceImageFormatProperties vkGetPhysicalDeviceImageFormatProperties = 0;\r
+ PFN_vkGetPhysicalDeviceImageFormatProperties2 vkGetPhysicalDeviceImageFormatProperties2 = 0;\r
+ PFN_vkGetPhysicalDeviceImageFormatProperties2KHR vkGetPhysicalDeviceImageFormatProperties2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceMemoryProperties vkGetPhysicalDeviceMemoryProperties = 0;\r
+ PFN_vkGetPhysicalDeviceMemoryProperties2 vkGetPhysicalDeviceMemoryProperties2 = 0;\r
+ PFN_vkGetPhysicalDeviceMemoryProperties2KHR vkGetPhysicalDeviceMemoryProperties2KHR = 0;\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ PFN_vkGetPhysicalDeviceMirPresentationSupportKHR vkGetPhysicalDeviceMirPresentationSupportKHR = 0;\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+ PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT vkGetPhysicalDeviceMultisamplePropertiesEXT = 0;\r
+ PFN_vkGetPhysicalDevicePresentRectanglesKHR vkGetPhysicalDevicePresentRectanglesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceProperties vkGetPhysicalDeviceProperties = 0;\r
+ PFN_vkGetPhysicalDeviceProperties2 vkGetPhysicalDeviceProperties2 = 0;\r
+ PFN_vkGetPhysicalDeviceProperties2KHR vkGetPhysicalDeviceProperties2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceQueueFamilyProperties vkGetPhysicalDeviceQueueFamilyProperties = 0;\r
+ PFN_vkGetPhysicalDeviceQueueFamilyProperties2 vkGetPhysicalDeviceQueueFamilyProperties2 = 0;\r
+ PFN_vkGetPhysicalDeviceQueueFamilyProperties2KHR vkGetPhysicalDeviceQueueFamilyProperties2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceSparseImageFormatProperties vkGetPhysicalDeviceSparseImageFormatProperties = 0;\r
+ PFN_vkGetPhysicalDeviceSparseImageFormatProperties2 vkGetPhysicalDeviceSparseImageFormatProperties2 = 0;\r
+ PFN_vkGetPhysicalDeviceSparseImageFormatProperties2KHR vkGetPhysicalDeviceSparseImageFormatProperties2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceSurfaceCapabilities2EXT vkGetPhysicalDeviceSurfaceCapabilities2EXT = 0;\r
+ PFN_vkGetPhysicalDeviceSurfaceCapabilities2KHR vkGetPhysicalDeviceSurfaceCapabilities2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR vkGetPhysicalDeviceSurfaceCapabilitiesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceSurfaceFormats2KHR vkGetPhysicalDeviceSurfaceFormats2KHR = 0;\r
+ PFN_vkGetPhysicalDeviceSurfaceFormatsKHR vkGetPhysicalDeviceSurfaceFormatsKHR = 0;\r
+ PFN_vkGetPhysicalDeviceSurfacePresentModesKHR vkGetPhysicalDeviceSurfacePresentModesKHR = 0;\r
+ PFN_vkGetPhysicalDeviceSurfaceSupportKHR vkGetPhysicalDeviceSurfaceSupportKHR = 0;\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR vkGetPhysicalDeviceWaylandPresentationSupportKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR vkGetPhysicalDeviceWin32PresentationSupportKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR vkGetPhysicalDeviceXcbPresentationSupportKHR = 0;\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR vkGetPhysicalDeviceXlibPresentationSupportKHR = 0;\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+ PFN_vkGetPipelineCacheData vkGetPipelineCacheData = 0;\r
+ PFN_vkGetQueryPoolResults vkGetQueryPoolResults = 0;\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ PFN_vkGetRandROutputDisplayEXT vkGetRandROutputDisplayEXT = 0;\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+ PFN_vkGetRefreshCycleDurationGOOGLE vkGetRefreshCycleDurationGOOGLE = 0;\r
+ PFN_vkGetRenderAreaGranularity vkGetRenderAreaGranularity = 0;\r
+ PFN_vkGetSemaphoreFdKHR vkGetSemaphoreFdKHR = 0;\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkGetSemaphoreWin32HandleKHR vkGetSemaphoreWin32HandleKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ PFN_vkGetShaderInfoAMD vkGetShaderInfoAMD = 0;\r
+ PFN_vkGetSwapchainCounterEXT vkGetSwapchainCounterEXT = 0;\r
+ PFN_vkGetSwapchainImagesKHR vkGetSwapchainImagesKHR = 0;\r
+ PFN_vkGetSwapchainStatusKHR vkGetSwapchainStatusKHR = 0;\r
+ PFN_vkGetValidationCacheDataEXT vkGetValidationCacheDataEXT = 0;\r
+ PFN_vkImportFenceFdKHR vkImportFenceFdKHR = 0;\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkImportFenceWin32HandleKHR vkImportFenceWin32HandleKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ PFN_vkImportSemaphoreFdKHR vkImportSemaphoreFdKHR = 0;\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ PFN_vkImportSemaphoreWin32HandleKHR vkImportSemaphoreWin32HandleKHR = 0;\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ PFN_vkInvalidateMappedMemoryRanges vkInvalidateMappedMemoryRanges = 0;\r
+ PFN_vkMapMemory vkMapMemory = 0;\r
+ PFN_vkMergePipelineCaches vkMergePipelineCaches = 0;\r
+ PFN_vkMergeValidationCachesEXT vkMergeValidationCachesEXT = 0;\r
+ PFN_vkQueueBeginDebugUtilsLabelEXT vkQueueBeginDebugUtilsLabelEXT = 0;\r
+ PFN_vkQueueBindSparse vkQueueBindSparse = 0;\r
+ PFN_vkQueueEndDebugUtilsLabelEXT vkQueueEndDebugUtilsLabelEXT = 0;\r
+ PFN_vkQueueInsertDebugUtilsLabelEXT vkQueueInsertDebugUtilsLabelEXT = 0;\r
+ PFN_vkQueuePresentKHR vkQueuePresentKHR = 0;\r
+ PFN_vkQueueSubmit vkQueueSubmit = 0;\r
+ PFN_vkQueueWaitIdle vkQueueWaitIdle = 0;\r
+ PFN_vkRegisterDeviceEventEXT vkRegisterDeviceEventEXT = 0;\r
+ PFN_vkRegisterDisplayEventEXT vkRegisterDisplayEventEXT = 0;\r
+ PFN_vkRegisterObjectsNVX vkRegisterObjectsNVX = 0;\r
+ PFN_vkReleaseDisplayEXT vkReleaseDisplayEXT = 0;\r
+ PFN_vkResetCommandBuffer vkResetCommandBuffer = 0;\r
+ PFN_vkResetCommandPool vkResetCommandPool = 0;\r
+ PFN_vkResetDescriptorPool vkResetDescriptorPool = 0;\r
+ PFN_vkResetEvent vkResetEvent = 0;\r
+ PFN_vkResetFences vkResetFences = 0;\r
+ PFN_vkSetDebugUtilsObjectNameEXT vkSetDebugUtilsObjectNameEXT = 0;\r
+ PFN_vkSetDebugUtilsObjectTagEXT vkSetDebugUtilsObjectTagEXT = 0;\r
+ PFN_vkSetEvent vkSetEvent = 0;\r
+ PFN_vkSetHdrMetadataEXT vkSetHdrMetadataEXT = 0;\r
+ PFN_vkSubmitDebugUtilsMessageEXT vkSubmitDebugUtilsMessageEXT = 0;\r
+ PFN_vkTrimCommandPool vkTrimCommandPool = 0;\r
+ PFN_vkTrimCommandPoolKHR vkTrimCommandPoolKHR = 0;\r
+ PFN_vkUnmapMemory vkUnmapMemory = 0;\r
+ PFN_vkUnregisterObjectsNVX vkUnregisterObjectsNVX = 0;\r
+ PFN_vkUpdateDescriptorSetWithTemplate vkUpdateDescriptorSetWithTemplate = 0;\r
+ PFN_vkUpdateDescriptorSetWithTemplateKHR vkUpdateDescriptorSetWithTemplateKHR = 0;\r
+ PFN_vkUpdateDescriptorSets vkUpdateDescriptorSets = 0;\r
+ PFN_vkWaitForFences vkWaitForFences = 0;\r
+ public:\r
+ DispatchLoaderDynamic(Instance instance = Instance(), Device device = Device())\r
+ {\r
+ if (instance)\r
+ {\r
+ init(instance, device);\r
+ }\r
+ }\r
+\r
+ void init(Instance instance, Device device = Device())\r
+ {\r
+ vkAcquireNextImage2KHR = PFN_vkAcquireNextImage2KHR(device ? device.getProcAddr( "vkAcquireNextImage2KHR") : instance.getProcAddr( "vkAcquireNextImage2KHR"));\r
+ vkAcquireNextImageKHR = PFN_vkAcquireNextImageKHR(device ? device.getProcAddr( "vkAcquireNextImageKHR") : instance.getProcAddr( "vkAcquireNextImageKHR"));\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ vkAcquireXlibDisplayEXT = PFN_vkAcquireXlibDisplayEXT(device ? device.getProcAddr( "vkAcquireXlibDisplayEXT") : instance.getProcAddr( "vkAcquireXlibDisplayEXT"));\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+ vkAllocateCommandBuffers = PFN_vkAllocateCommandBuffers(device ? device.getProcAddr( "vkAllocateCommandBuffers") : instance.getProcAddr( "vkAllocateCommandBuffers"));\r
+ vkAllocateDescriptorSets = PFN_vkAllocateDescriptorSets(device ? device.getProcAddr( "vkAllocateDescriptorSets") : instance.getProcAddr( "vkAllocateDescriptorSets"));\r
+ vkAllocateMemory = PFN_vkAllocateMemory(device ? device.getProcAddr( "vkAllocateMemory") : instance.getProcAddr( "vkAllocateMemory"));\r
+ vkBeginCommandBuffer = PFN_vkBeginCommandBuffer(device ? device.getProcAddr( "vkBeginCommandBuffer") : instance.getProcAddr( "vkBeginCommandBuffer"));\r
+ vkBindBufferMemory = PFN_vkBindBufferMemory(device ? device.getProcAddr( "vkBindBufferMemory") : instance.getProcAddr( "vkBindBufferMemory"));\r
+ vkBindBufferMemory2 = PFN_vkBindBufferMemory2(device ? device.getProcAddr( "vkBindBufferMemory2") : instance.getProcAddr( "vkBindBufferMemory2"));\r
+ vkBindBufferMemory2KHR = PFN_vkBindBufferMemory2KHR(device ? device.getProcAddr( "vkBindBufferMemory2KHR") : instance.getProcAddr( "vkBindBufferMemory2KHR"));\r
+ vkBindImageMemory = PFN_vkBindImageMemory(device ? device.getProcAddr( "vkBindImageMemory") : instance.getProcAddr( "vkBindImageMemory"));\r
+ vkBindImageMemory2 = PFN_vkBindImageMemory2(device ? device.getProcAddr( "vkBindImageMemory2") : instance.getProcAddr( "vkBindImageMemory2"));\r
+ vkBindImageMemory2KHR = PFN_vkBindImageMemory2KHR(device ? device.getProcAddr( "vkBindImageMemory2KHR") : instance.getProcAddr( "vkBindImageMemory2KHR"));\r
+ vkCmdBeginDebugUtilsLabelEXT = PFN_vkCmdBeginDebugUtilsLabelEXT(device ? device.getProcAddr( "vkCmdBeginDebugUtilsLabelEXT") : instance.getProcAddr( "vkCmdBeginDebugUtilsLabelEXT"));\r
+ vkCmdBeginQuery = PFN_vkCmdBeginQuery(device ? device.getProcAddr( "vkCmdBeginQuery") : instance.getProcAddr( "vkCmdBeginQuery"));\r
+ vkCmdBeginRenderPass = PFN_vkCmdBeginRenderPass(device ? device.getProcAddr( "vkCmdBeginRenderPass") : instance.getProcAddr( "vkCmdBeginRenderPass"));\r
+ vkCmdBindDescriptorSets = PFN_vkCmdBindDescriptorSets(device ? device.getProcAddr( "vkCmdBindDescriptorSets") : instance.getProcAddr( "vkCmdBindDescriptorSets"));\r
+ vkCmdBindIndexBuffer = PFN_vkCmdBindIndexBuffer(device ? device.getProcAddr( "vkCmdBindIndexBuffer") : instance.getProcAddr( "vkCmdBindIndexBuffer"));\r
+ vkCmdBindPipeline = PFN_vkCmdBindPipeline(device ? device.getProcAddr( "vkCmdBindPipeline") : instance.getProcAddr( "vkCmdBindPipeline"));\r
+ vkCmdBindVertexBuffers = PFN_vkCmdBindVertexBuffers(device ? device.getProcAddr( "vkCmdBindVertexBuffers") : instance.getProcAddr( "vkCmdBindVertexBuffers"));\r
+ vkCmdBlitImage = PFN_vkCmdBlitImage(device ? device.getProcAddr( "vkCmdBlitImage") : instance.getProcAddr( "vkCmdBlitImage"));\r
+ vkCmdClearAttachments = PFN_vkCmdClearAttachments(device ? device.getProcAddr( "vkCmdClearAttachments") : instance.getProcAddr( "vkCmdClearAttachments"));\r
+ vkCmdClearColorImage = PFN_vkCmdClearColorImage(device ? device.getProcAddr( "vkCmdClearColorImage") : instance.getProcAddr( "vkCmdClearColorImage"));\r
+ vkCmdClearDepthStencilImage = PFN_vkCmdClearDepthStencilImage(device ? device.getProcAddr( "vkCmdClearDepthStencilImage") : instance.getProcAddr( "vkCmdClearDepthStencilImage"));\r
+ vkCmdCopyBuffer = PFN_vkCmdCopyBuffer(device ? device.getProcAddr( "vkCmdCopyBuffer") : instance.getProcAddr( "vkCmdCopyBuffer"));\r
+ vkCmdCopyBufferToImage = PFN_vkCmdCopyBufferToImage(device ? device.getProcAddr( "vkCmdCopyBufferToImage") : instance.getProcAddr( "vkCmdCopyBufferToImage"));\r
+ vkCmdCopyImage = PFN_vkCmdCopyImage(device ? device.getProcAddr( "vkCmdCopyImage") : instance.getProcAddr( "vkCmdCopyImage"));\r
+ vkCmdCopyImageToBuffer = PFN_vkCmdCopyImageToBuffer(device ? device.getProcAddr( "vkCmdCopyImageToBuffer") : instance.getProcAddr( "vkCmdCopyImageToBuffer"));\r
+ vkCmdCopyQueryPoolResults = PFN_vkCmdCopyQueryPoolResults(device ? device.getProcAddr( "vkCmdCopyQueryPoolResults") : instance.getProcAddr( "vkCmdCopyQueryPoolResults"));\r
+ vkCmdDebugMarkerBeginEXT = PFN_vkCmdDebugMarkerBeginEXT(device ? device.getProcAddr( "vkCmdDebugMarkerBeginEXT") : instance.getProcAddr( "vkCmdDebugMarkerBeginEXT"));\r
+ vkCmdDebugMarkerEndEXT = PFN_vkCmdDebugMarkerEndEXT(device ? device.getProcAddr( "vkCmdDebugMarkerEndEXT") : instance.getProcAddr( "vkCmdDebugMarkerEndEXT"));\r
+ vkCmdDebugMarkerInsertEXT = PFN_vkCmdDebugMarkerInsertEXT(device ? device.getProcAddr( "vkCmdDebugMarkerInsertEXT") : instance.getProcAddr( "vkCmdDebugMarkerInsertEXT"));\r
+ vkCmdDispatch = PFN_vkCmdDispatch(device ? device.getProcAddr( "vkCmdDispatch") : instance.getProcAddr( "vkCmdDispatch"));\r
+ vkCmdDispatchBase = PFN_vkCmdDispatchBase(device ? device.getProcAddr( "vkCmdDispatchBase") : instance.getProcAddr( "vkCmdDispatchBase"));\r
+ vkCmdDispatchBaseKHR = PFN_vkCmdDispatchBaseKHR(device ? device.getProcAddr( "vkCmdDispatchBaseKHR") : instance.getProcAddr( "vkCmdDispatchBaseKHR"));\r
+ vkCmdDispatchIndirect = PFN_vkCmdDispatchIndirect(device ? device.getProcAddr( "vkCmdDispatchIndirect") : instance.getProcAddr( "vkCmdDispatchIndirect"));\r
+ vkCmdDraw = PFN_vkCmdDraw(device ? device.getProcAddr( "vkCmdDraw") : instance.getProcAddr( "vkCmdDraw"));\r
+ vkCmdDrawIndexed = PFN_vkCmdDrawIndexed(device ? device.getProcAddr( "vkCmdDrawIndexed") : instance.getProcAddr( "vkCmdDrawIndexed"));\r
+ vkCmdDrawIndexedIndirect = PFN_vkCmdDrawIndexedIndirect(device ? device.getProcAddr( "vkCmdDrawIndexedIndirect") : instance.getProcAddr( "vkCmdDrawIndexedIndirect"));\r
+ vkCmdDrawIndexedIndirectCountAMD = PFN_vkCmdDrawIndexedIndirectCountAMD(device ? device.getProcAddr( "vkCmdDrawIndexedIndirectCountAMD") : instance.getProcAddr( "vkCmdDrawIndexedIndirectCountAMD"));\r
+ vkCmdDrawIndirect = PFN_vkCmdDrawIndirect(device ? device.getProcAddr( "vkCmdDrawIndirect") : instance.getProcAddr( "vkCmdDrawIndirect"));\r
+ vkCmdDrawIndirectCountAMD = PFN_vkCmdDrawIndirectCountAMD(device ? device.getProcAddr( "vkCmdDrawIndirectCountAMD") : instance.getProcAddr( "vkCmdDrawIndirectCountAMD"));\r
+ vkCmdEndDebugUtilsLabelEXT = PFN_vkCmdEndDebugUtilsLabelEXT(device ? device.getProcAddr( "vkCmdEndDebugUtilsLabelEXT") : instance.getProcAddr( "vkCmdEndDebugUtilsLabelEXT"));\r
+ vkCmdEndQuery = PFN_vkCmdEndQuery(device ? device.getProcAddr( "vkCmdEndQuery") : instance.getProcAddr( "vkCmdEndQuery"));\r
+ vkCmdEndRenderPass = PFN_vkCmdEndRenderPass(device ? device.getProcAddr( "vkCmdEndRenderPass") : instance.getProcAddr( "vkCmdEndRenderPass"));\r
+ vkCmdExecuteCommands = PFN_vkCmdExecuteCommands(device ? device.getProcAddr( "vkCmdExecuteCommands") : instance.getProcAddr( "vkCmdExecuteCommands"));\r
+ vkCmdFillBuffer = PFN_vkCmdFillBuffer(device ? device.getProcAddr( "vkCmdFillBuffer") : instance.getProcAddr( "vkCmdFillBuffer"));\r
+ vkCmdInsertDebugUtilsLabelEXT = PFN_vkCmdInsertDebugUtilsLabelEXT(device ? device.getProcAddr( "vkCmdInsertDebugUtilsLabelEXT") : instance.getProcAddr( "vkCmdInsertDebugUtilsLabelEXT"));\r
+ vkCmdNextSubpass = PFN_vkCmdNextSubpass(device ? device.getProcAddr( "vkCmdNextSubpass") : instance.getProcAddr( "vkCmdNextSubpass"));\r
+ vkCmdPipelineBarrier = PFN_vkCmdPipelineBarrier(device ? device.getProcAddr( "vkCmdPipelineBarrier") : instance.getProcAddr( "vkCmdPipelineBarrier"));\r
+ vkCmdProcessCommandsNVX = PFN_vkCmdProcessCommandsNVX(device ? device.getProcAddr( "vkCmdProcessCommandsNVX") : instance.getProcAddr( "vkCmdProcessCommandsNVX"));\r
+ vkCmdPushConstants = PFN_vkCmdPushConstants(device ? device.getProcAddr( "vkCmdPushConstants") : instance.getProcAddr( "vkCmdPushConstants"));\r
+ vkCmdPushDescriptorSetKHR = PFN_vkCmdPushDescriptorSetKHR(device ? device.getProcAddr( "vkCmdPushDescriptorSetKHR") : instance.getProcAddr( "vkCmdPushDescriptorSetKHR"));\r
+ vkCmdPushDescriptorSetWithTemplateKHR = PFN_vkCmdPushDescriptorSetWithTemplateKHR(device ? device.getProcAddr( "vkCmdPushDescriptorSetWithTemplateKHR") : instance.getProcAddr( "vkCmdPushDescriptorSetWithTemplateKHR"));\r
+ vkCmdReserveSpaceForCommandsNVX = PFN_vkCmdReserveSpaceForCommandsNVX(device ? device.getProcAddr( "vkCmdReserveSpaceForCommandsNVX") : instance.getProcAddr( "vkCmdReserveSpaceForCommandsNVX"));\r
+ vkCmdResetEvent = PFN_vkCmdResetEvent(device ? device.getProcAddr( "vkCmdResetEvent") : instance.getProcAddr( "vkCmdResetEvent"));\r
+ vkCmdResetQueryPool = PFN_vkCmdResetQueryPool(device ? device.getProcAddr( "vkCmdResetQueryPool") : instance.getProcAddr( "vkCmdResetQueryPool"));\r
+ vkCmdResolveImage = PFN_vkCmdResolveImage(device ? device.getProcAddr( "vkCmdResolveImage") : instance.getProcAddr( "vkCmdResolveImage"));\r
+ vkCmdSetBlendConstants = PFN_vkCmdSetBlendConstants(device ? device.getProcAddr( "vkCmdSetBlendConstants") : instance.getProcAddr( "vkCmdSetBlendConstants"));\r
+ vkCmdSetDepthBias = PFN_vkCmdSetDepthBias(device ? device.getProcAddr( "vkCmdSetDepthBias") : instance.getProcAddr( "vkCmdSetDepthBias"));\r
+ vkCmdSetDepthBounds = PFN_vkCmdSetDepthBounds(device ? device.getProcAddr( "vkCmdSetDepthBounds") : instance.getProcAddr( "vkCmdSetDepthBounds"));\r
+ vkCmdSetDeviceMask = PFN_vkCmdSetDeviceMask(device ? device.getProcAddr( "vkCmdSetDeviceMask") : instance.getProcAddr( "vkCmdSetDeviceMask"));\r
+ vkCmdSetDeviceMaskKHR = PFN_vkCmdSetDeviceMaskKHR(device ? device.getProcAddr( "vkCmdSetDeviceMaskKHR") : instance.getProcAddr( "vkCmdSetDeviceMaskKHR"));\r
+ vkCmdSetDiscardRectangleEXT = PFN_vkCmdSetDiscardRectangleEXT(device ? device.getProcAddr( "vkCmdSetDiscardRectangleEXT") : instance.getProcAddr( "vkCmdSetDiscardRectangleEXT"));\r
+ vkCmdSetEvent = PFN_vkCmdSetEvent(device ? device.getProcAddr( "vkCmdSetEvent") : instance.getProcAddr( "vkCmdSetEvent"));\r
+ vkCmdSetLineWidth = PFN_vkCmdSetLineWidth(device ? device.getProcAddr( "vkCmdSetLineWidth") : instance.getProcAddr( "vkCmdSetLineWidth"));\r
+ vkCmdSetSampleLocationsEXT = PFN_vkCmdSetSampleLocationsEXT(device ? device.getProcAddr( "vkCmdSetSampleLocationsEXT") : instance.getProcAddr( "vkCmdSetSampleLocationsEXT"));\r
+ vkCmdSetScissor = PFN_vkCmdSetScissor(device ? device.getProcAddr( "vkCmdSetScissor") : instance.getProcAddr( "vkCmdSetScissor"));\r
+ vkCmdSetStencilCompareMask = PFN_vkCmdSetStencilCompareMask(device ? device.getProcAddr( "vkCmdSetStencilCompareMask") : instance.getProcAddr( "vkCmdSetStencilCompareMask"));\r
+ vkCmdSetStencilReference = PFN_vkCmdSetStencilReference(device ? device.getProcAddr( "vkCmdSetStencilReference") : instance.getProcAddr( "vkCmdSetStencilReference"));\r
+ vkCmdSetStencilWriteMask = PFN_vkCmdSetStencilWriteMask(device ? device.getProcAddr( "vkCmdSetStencilWriteMask") : instance.getProcAddr( "vkCmdSetStencilWriteMask"));\r
+ vkCmdSetViewport = PFN_vkCmdSetViewport(device ? device.getProcAddr( "vkCmdSetViewport") : instance.getProcAddr( "vkCmdSetViewport"));\r
+ vkCmdSetViewportWScalingNV = PFN_vkCmdSetViewportWScalingNV(device ? device.getProcAddr( "vkCmdSetViewportWScalingNV") : instance.getProcAddr( "vkCmdSetViewportWScalingNV"));\r
+ vkCmdUpdateBuffer = PFN_vkCmdUpdateBuffer(device ? device.getProcAddr( "vkCmdUpdateBuffer") : instance.getProcAddr( "vkCmdUpdateBuffer"));\r
+ vkCmdWaitEvents = PFN_vkCmdWaitEvents(device ? device.getProcAddr( "vkCmdWaitEvents") : instance.getProcAddr( "vkCmdWaitEvents"));\r
+ vkCmdWriteBufferMarkerAMD = PFN_vkCmdWriteBufferMarkerAMD(device ? device.getProcAddr( "vkCmdWriteBufferMarkerAMD") : instance.getProcAddr( "vkCmdWriteBufferMarkerAMD"));\r
+ vkCmdWriteTimestamp = PFN_vkCmdWriteTimestamp(device ? device.getProcAddr( "vkCmdWriteTimestamp") : instance.getProcAddr( "vkCmdWriteTimestamp"));\r
+#ifdef VK_USE_PLATFORM_ANDROID_KHR\r
+ vkCreateAndroidSurfaceKHR = PFN_vkCreateAndroidSurfaceKHR(instance.getProcAddr( "vkCreateAndroidSurfaceKHR"));\r
+#endif /*VK_USE_PLATFORM_ANDROID_KHR*/\r
+ vkCreateBuffer = PFN_vkCreateBuffer(device ? device.getProcAddr( "vkCreateBuffer") : instance.getProcAddr( "vkCreateBuffer"));\r
+ vkCreateBufferView = PFN_vkCreateBufferView(device ? device.getProcAddr( "vkCreateBufferView") : instance.getProcAddr( "vkCreateBufferView"));\r
+ vkCreateCommandPool = PFN_vkCreateCommandPool(device ? device.getProcAddr( "vkCreateCommandPool") : instance.getProcAddr( "vkCreateCommandPool"));\r
+ vkCreateComputePipelines = PFN_vkCreateComputePipelines(device ? device.getProcAddr( "vkCreateComputePipelines") : instance.getProcAddr( "vkCreateComputePipelines"));\r
+ vkCreateDebugReportCallbackEXT = PFN_vkCreateDebugReportCallbackEXT(instance.getProcAddr( "vkCreateDebugReportCallbackEXT"));\r
+ vkCreateDebugUtilsMessengerEXT = PFN_vkCreateDebugUtilsMessengerEXT(instance.getProcAddr( "vkCreateDebugUtilsMessengerEXT"));\r
+ vkCreateDescriptorPool = PFN_vkCreateDescriptorPool(device ? device.getProcAddr( "vkCreateDescriptorPool") : instance.getProcAddr( "vkCreateDescriptorPool"));\r
+ vkCreateDescriptorSetLayout = PFN_vkCreateDescriptorSetLayout(device ? device.getProcAddr( "vkCreateDescriptorSetLayout") : instance.getProcAddr( "vkCreateDescriptorSetLayout"));\r
+ vkCreateDescriptorUpdateTemplate = PFN_vkCreateDescriptorUpdateTemplate(device ? device.getProcAddr( "vkCreateDescriptorUpdateTemplate") : instance.getProcAddr( "vkCreateDescriptorUpdateTemplate"));\r
+ vkCreateDescriptorUpdateTemplateKHR = PFN_vkCreateDescriptorUpdateTemplateKHR(device ? device.getProcAddr( "vkCreateDescriptorUpdateTemplateKHR") : instance.getProcAddr( "vkCreateDescriptorUpdateTemplateKHR"));\r
+ vkCreateDevice = PFN_vkCreateDevice(device ? device.getProcAddr( "vkCreateDevice") : instance.getProcAddr( "vkCreateDevice"));\r
+ vkCreateDisplayModeKHR = PFN_vkCreateDisplayModeKHR(device ? device.getProcAddr( "vkCreateDisplayModeKHR") : instance.getProcAddr( "vkCreateDisplayModeKHR"));\r
+ vkCreateDisplayPlaneSurfaceKHR = PFN_vkCreateDisplayPlaneSurfaceKHR(instance.getProcAddr( "vkCreateDisplayPlaneSurfaceKHR"));\r
+ vkCreateEvent = PFN_vkCreateEvent(device ? device.getProcAddr( "vkCreateEvent") : instance.getProcAddr( "vkCreateEvent"));\r
+ vkCreateFence = PFN_vkCreateFence(device ? device.getProcAddr( "vkCreateFence") : instance.getProcAddr( "vkCreateFence"));\r
+ vkCreateFramebuffer = PFN_vkCreateFramebuffer(device ? device.getProcAddr( "vkCreateFramebuffer") : instance.getProcAddr( "vkCreateFramebuffer"));\r
+ vkCreateGraphicsPipelines = PFN_vkCreateGraphicsPipelines(device ? device.getProcAddr( "vkCreateGraphicsPipelines") : instance.getProcAddr( "vkCreateGraphicsPipelines"));\r
+#ifdef VK_USE_PLATFORM_IOS_MVK\r
+ vkCreateIOSSurfaceMVK = PFN_vkCreateIOSSurfaceMVK(instance.getProcAddr( "vkCreateIOSSurfaceMVK"));\r
+#endif /*VK_USE_PLATFORM_IOS_MVK*/\r
+ vkCreateImage = PFN_vkCreateImage(device ? device.getProcAddr( "vkCreateImage") : instance.getProcAddr( "vkCreateImage"));\r
+ vkCreateImageView = PFN_vkCreateImageView(device ? device.getProcAddr( "vkCreateImageView") : instance.getProcAddr( "vkCreateImageView"));\r
+ vkCreateIndirectCommandsLayoutNVX = PFN_vkCreateIndirectCommandsLayoutNVX(device ? device.getProcAddr( "vkCreateIndirectCommandsLayoutNVX") : instance.getProcAddr( "vkCreateIndirectCommandsLayoutNVX"));\r
+ vkCreateInstance = PFN_vkCreateInstance(instance.getProcAddr( "vkCreateInstance"));\r
+#ifdef VK_USE_PLATFORM_MACOS_MVK\r
+ vkCreateMacOSSurfaceMVK = PFN_vkCreateMacOSSurfaceMVK(instance.getProcAddr( "vkCreateMacOSSurfaceMVK"));\r
+#endif /*VK_USE_PLATFORM_MACOS_MVK*/\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ vkCreateMirSurfaceKHR = PFN_vkCreateMirSurfaceKHR(instance.getProcAddr( "vkCreateMirSurfaceKHR"));\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+ vkCreateObjectTableNVX = PFN_vkCreateObjectTableNVX(device ? device.getProcAddr( "vkCreateObjectTableNVX") : instance.getProcAddr( "vkCreateObjectTableNVX"));\r
+ vkCreatePipelineCache = PFN_vkCreatePipelineCache(device ? device.getProcAddr( "vkCreatePipelineCache") : instance.getProcAddr( "vkCreatePipelineCache"));\r
+ vkCreatePipelineLayout = PFN_vkCreatePipelineLayout(device ? device.getProcAddr( "vkCreatePipelineLayout") : instance.getProcAddr( "vkCreatePipelineLayout"));\r
+ vkCreateQueryPool = PFN_vkCreateQueryPool(device ? device.getProcAddr( "vkCreateQueryPool") : instance.getProcAddr( "vkCreateQueryPool"));\r
+ vkCreateRenderPass = PFN_vkCreateRenderPass(device ? device.getProcAddr( "vkCreateRenderPass") : instance.getProcAddr( "vkCreateRenderPass"));\r
+ vkCreateSampler = PFN_vkCreateSampler(device ? device.getProcAddr( "vkCreateSampler") : instance.getProcAddr( "vkCreateSampler"));\r
+ vkCreateSamplerYcbcrConversion = PFN_vkCreateSamplerYcbcrConversion(device ? device.getProcAddr( "vkCreateSamplerYcbcrConversion") : instance.getProcAddr( "vkCreateSamplerYcbcrConversion"));\r
+ vkCreateSamplerYcbcrConversionKHR = PFN_vkCreateSamplerYcbcrConversionKHR(device ? device.getProcAddr( "vkCreateSamplerYcbcrConversionKHR") : instance.getProcAddr( "vkCreateSamplerYcbcrConversionKHR"));\r
+ vkCreateSemaphore = PFN_vkCreateSemaphore(device ? device.getProcAddr( "vkCreateSemaphore") : instance.getProcAddr( "vkCreateSemaphore"));\r
+ vkCreateShaderModule = PFN_vkCreateShaderModule(device ? device.getProcAddr( "vkCreateShaderModule") : instance.getProcAddr( "vkCreateShaderModule"));\r
+ vkCreateSharedSwapchainsKHR = PFN_vkCreateSharedSwapchainsKHR(device ? device.getProcAddr( "vkCreateSharedSwapchainsKHR") : instance.getProcAddr( "vkCreateSharedSwapchainsKHR"));\r
+ vkCreateSwapchainKHR = PFN_vkCreateSwapchainKHR(device ? device.getProcAddr( "vkCreateSwapchainKHR") : instance.getProcAddr( "vkCreateSwapchainKHR"));\r
+ vkCreateValidationCacheEXT = PFN_vkCreateValidationCacheEXT(device ? device.getProcAddr( "vkCreateValidationCacheEXT") : instance.getProcAddr( "vkCreateValidationCacheEXT"));\r
+#ifdef VK_USE_PLATFORM_VI_NN\r
+ vkCreateViSurfaceNN = PFN_vkCreateViSurfaceNN(instance.getProcAddr( "vkCreateViSurfaceNN"));\r
+#endif /*VK_USE_PLATFORM_VI_NN*/\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ vkCreateWaylandSurfaceKHR = PFN_vkCreateWaylandSurfaceKHR(instance.getProcAddr( "vkCreateWaylandSurfaceKHR"));\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkCreateWin32SurfaceKHR = PFN_vkCreateWin32SurfaceKHR(instance.getProcAddr( "vkCreateWin32SurfaceKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ vkCreateXcbSurfaceKHR = PFN_vkCreateXcbSurfaceKHR(instance.getProcAddr( "vkCreateXcbSurfaceKHR"));\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ vkCreateXlibSurfaceKHR = PFN_vkCreateXlibSurfaceKHR(instance.getProcAddr( "vkCreateXlibSurfaceKHR"));\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+ vkDebugMarkerSetObjectNameEXT = PFN_vkDebugMarkerSetObjectNameEXT(device ? device.getProcAddr( "vkDebugMarkerSetObjectNameEXT") : instance.getProcAddr( "vkDebugMarkerSetObjectNameEXT"));\r
+ vkDebugMarkerSetObjectTagEXT = PFN_vkDebugMarkerSetObjectTagEXT(device ? device.getProcAddr( "vkDebugMarkerSetObjectTagEXT") : instance.getProcAddr( "vkDebugMarkerSetObjectTagEXT"));\r
+ vkDebugReportMessageEXT = PFN_vkDebugReportMessageEXT(instance.getProcAddr( "vkDebugReportMessageEXT"));\r
+ vkDestroyBuffer = PFN_vkDestroyBuffer(device ? device.getProcAddr( "vkDestroyBuffer") : instance.getProcAddr( "vkDestroyBuffer"));\r
+ vkDestroyBufferView = PFN_vkDestroyBufferView(device ? device.getProcAddr( "vkDestroyBufferView") : instance.getProcAddr( "vkDestroyBufferView"));\r
+ vkDestroyCommandPool = PFN_vkDestroyCommandPool(device ? device.getProcAddr( "vkDestroyCommandPool") : instance.getProcAddr( "vkDestroyCommandPool"));\r
+ vkDestroyDebugReportCallbackEXT = PFN_vkDestroyDebugReportCallbackEXT(instance.getProcAddr( "vkDestroyDebugReportCallbackEXT"));\r
+ vkDestroyDebugUtilsMessengerEXT = PFN_vkDestroyDebugUtilsMessengerEXT(instance.getProcAddr( "vkDestroyDebugUtilsMessengerEXT"));\r
+ vkDestroyDescriptorPool = PFN_vkDestroyDescriptorPool(device ? device.getProcAddr( "vkDestroyDescriptorPool") : instance.getProcAddr( "vkDestroyDescriptorPool"));\r
+ vkDestroyDescriptorSetLayout = PFN_vkDestroyDescriptorSetLayout(device ? device.getProcAddr( "vkDestroyDescriptorSetLayout") : instance.getProcAddr( "vkDestroyDescriptorSetLayout"));\r
+ vkDestroyDescriptorUpdateTemplate = PFN_vkDestroyDescriptorUpdateTemplate(device ? device.getProcAddr( "vkDestroyDescriptorUpdateTemplate") : instance.getProcAddr( "vkDestroyDescriptorUpdateTemplate"));\r
+ vkDestroyDescriptorUpdateTemplateKHR = PFN_vkDestroyDescriptorUpdateTemplateKHR(device ? device.getProcAddr( "vkDestroyDescriptorUpdateTemplateKHR") : instance.getProcAddr( "vkDestroyDescriptorUpdateTemplateKHR"));\r
+ vkDestroyDevice = PFN_vkDestroyDevice(device ? device.getProcAddr( "vkDestroyDevice") : instance.getProcAddr( "vkDestroyDevice"));\r
+ vkDestroyEvent = PFN_vkDestroyEvent(device ? device.getProcAddr( "vkDestroyEvent") : instance.getProcAddr( "vkDestroyEvent"));\r
+ vkDestroyFence = PFN_vkDestroyFence(device ? device.getProcAddr( "vkDestroyFence") : instance.getProcAddr( "vkDestroyFence"));\r
+ vkDestroyFramebuffer = PFN_vkDestroyFramebuffer(device ? device.getProcAddr( "vkDestroyFramebuffer") : instance.getProcAddr( "vkDestroyFramebuffer"));\r
+ vkDestroyImage = PFN_vkDestroyImage(device ? device.getProcAddr( "vkDestroyImage") : instance.getProcAddr( "vkDestroyImage"));\r
+ vkDestroyImageView = PFN_vkDestroyImageView(device ? device.getProcAddr( "vkDestroyImageView") : instance.getProcAddr( "vkDestroyImageView"));\r
+ vkDestroyIndirectCommandsLayoutNVX = PFN_vkDestroyIndirectCommandsLayoutNVX(device ? device.getProcAddr( "vkDestroyIndirectCommandsLayoutNVX") : instance.getProcAddr( "vkDestroyIndirectCommandsLayoutNVX"));\r
+ vkDestroyInstance = PFN_vkDestroyInstance(instance.getProcAddr( "vkDestroyInstance"));\r
+ vkDestroyObjectTableNVX = PFN_vkDestroyObjectTableNVX(device ? device.getProcAddr( "vkDestroyObjectTableNVX") : instance.getProcAddr( "vkDestroyObjectTableNVX"));\r
+ vkDestroyPipeline = PFN_vkDestroyPipeline(device ? device.getProcAddr( "vkDestroyPipeline") : instance.getProcAddr( "vkDestroyPipeline"));\r
+ vkDestroyPipelineCache = PFN_vkDestroyPipelineCache(device ? device.getProcAddr( "vkDestroyPipelineCache") : instance.getProcAddr( "vkDestroyPipelineCache"));\r
+ vkDestroyPipelineLayout = PFN_vkDestroyPipelineLayout(device ? device.getProcAddr( "vkDestroyPipelineLayout") : instance.getProcAddr( "vkDestroyPipelineLayout"));\r
+ vkDestroyQueryPool = PFN_vkDestroyQueryPool(device ? device.getProcAddr( "vkDestroyQueryPool") : instance.getProcAddr( "vkDestroyQueryPool"));\r
+ vkDestroyRenderPass = PFN_vkDestroyRenderPass(device ? device.getProcAddr( "vkDestroyRenderPass") : instance.getProcAddr( "vkDestroyRenderPass"));\r
+ vkDestroySampler = PFN_vkDestroySampler(device ? device.getProcAddr( "vkDestroySampler") : instance.getProcAddr( "vkDestroySampler"));\r
+ vkDestroySamplerYcbcrConversion = PFN_vkDestroySamplerYcbcrConversion(device ? device.getProcAddr( "vkDestroySamplerYcbcrConversion") : instance.getProcAddr( "vkDestroySamplerYcbcrConversion"));\r
+ vkDestroySamplerYcbcrConversionKHR = PFN_vkDestroySamplerYcbcrConversionKHR(device ? device.getProcAddr( "vkDestroySamplerYcbcrConversionKHR") : instance.getProcAddr( "vkDestroySamplerYcbcrConversionKHR"));\r
+ vkDestroySemaphore = PFN_vkDestroySemaphore(device ? device.getProcAddr( "vkDestroySemaphore") : instance.getProcAddr( "vkDestroySemaphore"));\r
+ vkDestroyShaderModule = PFN_vkDestroyShaderModule(device ? device.getProcAddr( "vkDestroyShaderModule") : instance.getProcAddr( "vkDestroyShaderModule"));\r
+ vkDestroySurfaceKHR = PFN_vkDestroySurfaceKHR(instance.getProcAddr( "vkDestroySurfaceKHR"));\r
+ vkDestroySwapchainKHR = PFN_vkDestroySwapchainKHR(device ? device.getProcAddr( "vkDestroySwapchainKHR") : instance.getProcAddr( "vkDestroySwapchainKHR"));\r
+ vkDestroyValidationCacheEXT = PFN_vkDestroyValidationCacheEXT(device ? device.getProcAddr( "vkDestroyValidationCacheEXT") : instance.getProcAddr( "vkDestroyValidationCacheEXT"));\r
+ vkDeviceWaitIdle = PFN_vkDeviceWaitIdle(device ? device.getProcAddr( "vkDeviceWaitIdle") : instance.getProcAddr( "vkDeviceWaitIdle"));\r
+ vkDisplayPowerControlEXT = PFN_vkDisplayPowerControlEXT(device ? device.getProcAddr( "vkDisplayPowerControlEXT") : instance.getProcAddr( "vkDisplayPowerControlEXT"));\r
+ vkEndCommandBuffer = PFN_vkEndCommandBuffer(device ? device.getProcAddr( "vkEndCommandBuffer") : instance.getProcAddr( "vkEndCommandBuffer"));\r
+ vkEnumerateDeviceExtensionProperties = PFN_vkEnumerateDeviceExtensionProperties(device ? device.getProcAddr( "vkEnumerateDeviceExtensionProperties") : instance.getProcAddr( "vkEnumerateDeviceExtensionProperties"));\r
+ vkEnumerateDeviceLayerProperties = PFN_vkEnumerateDeviceLayerProperties(device ? device.getProcAddr( "vkEnumerateDeviceLayerProperties") : instance.getProcAddr( "vkEnumerateDeviceLayerProperties"));\r
+ vkEnumerateInstanceExtensionProperties = PFN_vkEnumerateInstanceExtensionProperties(instance.getProcAddr( "vkEnumerateInstanceExtensionProperties"));\r
+ vkEnumerateInstanceLayerProperties = PFN_vkEnumerateInstanceLayerProperties(instance.getProcAddr( "vkEnumerateInstanceLayerProperties"));\r
+ vkEnumerateInstanceVersion = PFN_vkEnumerateInstanceVersion(instance.getProcAddr( "vkEnumerateInstanceVersion"));\r
+ vkEnumeratePhysicalDeviceGroups = PFN_vkEnumeratePhysicalDeviceGroups(instance.getProcAddr( "vkEnumeratePhysicalDeviceGroups"));\r
+ vkEnumeratePhysicalDeviceGroupsKHR = PFN_vkEnumeratePhysicalDeviceGroupsKHR(instance.getProcAddr( "vkEnumeratePhysicalDeviceGroupsKHR"));\r
+ vkEnumeratePhysicalDevices = PFN_vkEnumeratePhysicalDevices(instance.getProcAddr( "vkEnumeratePhysicalDevices"));\r
+ vkFlushMappedMemoryRanges = PFN_vkFlushMappedMemoryRanges(device ? device.getProcAddr( "vkFlushMappedMemoryRanges") : instance.getProcAddr( "vkFlushMappedMemoryRanges"));\r
+ vkFreeCommandBuffers = PFN_vkFreeCommandBuffers(device ? device.getProcAddr( "vkFreeCommandBuffers") : instance.getProcAddr( "vkFreeCommandBuffers"));\r
+ vkFreeDescriptorSets = PFN_vkFreeDescriptorSets(device ? device.getProcAddr( "vkFreeDescriptorSets") : instance.getProcAddr( "vkFreeDescriptorSets"));\r
+ vkFreeMemory = PFN_vkFreeMemory(device ? device.getProcAddr( "vkFreeMemory") : instance.getProcAddr( "vkFreeMemory"));\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ vkGetAndroidHardwareBufferPropertiesANDROID = PFN_vkGetAndroidHardwareBufferPropertiesANDROID(device ? device.getProcAddr( "vkGetAndroidHardwareBufferPropertiesANDROID") : instance.getProcAddr( "vkGetAndroidHardwareBufferPropertiesANDROID"));\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ vkGetBufferMemoryRequirements = PFN_vkGetBufferMemoryRequirements(device ? device.getProcAddr( "vkGetBufferMemoryRequirements") : instance.getProcAddr( "vkGetBufferMemoryRequirements"));\r
+ vkGetBufferMemoryRequirements2 = PFN_vkGetBufferMemoryRequirements2(device ? device.getProcAddr( "vkGetBufferMemoryRequirements2") : instance.getProcAddr( "vkGetBufferMemoryRequirements2"));\r
+ vkGetBufferMemoryRequirements2KHR = PFN_vkGetBufferMemoryRequirements2KHR(device ? device.getProcAddr( "vkGetBufferMemoryRequirements2KHR") : instance.getProcAddr( "vkGetBufferMemoryRequirements2KHR"));\r
+ vkGetDescriptorSetLayoutSupport = PFN_vkGetDescriptorSetLayoutSupport(device ? device.getProcAddr( "vkGetDescriptorSetLayoutSupport") : instance.getProcAddr( "vkGetDescriptorSetLayoutSupport"));\r
+ vkGetDescriptorSetLayoutSupportKHR = PFN_vkGetDescriptorSetLayoutSupportKHR(device ? device.getProcAddr( "vkGetDescriptorSetLayoutSupportKHR") : instance.getProcAddr( "vkGetDescriptorSetLayoutSupportKHR"));\r
+ vkGetDeviceGroupPeerMemoryFeatures = PFN_vkGetDeviceGroupPeerMemoryFeatures(device ? device.getProcAddr( "vkGetDeviceGroupPeerMemoryFeatures") : instance.getProcAddr( "vkGetDeviceGroupPeerMemoryFeatures"));\r
+ vkGetDeviceGroupPeerMemoryFeaturesKHR = PFN_vkGetDeviceGroupPeerMemoryFeaturesKHR(device ? device.getProcAddr( "vkGetDeviceGroupPeerMemoryFeaturesKHR") : instance.getProcAddr( "vkGetDeviceGroupPeerMemoryFeaturesKHR"));\r
+ vkGetDeviceGroupPresentCapabilitiesKHR = PFN_vkGetDeviceGroupPresentCapabilitiesKHR(device ? device.getProcAddr( "vkGetDeviceGroupPresentCapabilitiesKHR") : instance.getProcAddr( "vkGetDeviceGroupPresentCapabilitiesKHR"));\r
+ vkGetDeviceGroupSurfacePresentModesKHR = PFN_vkGetDeviceGroupSurfacePresentModesKHR(device ? device.getProcAddr( "vkGetDeviceGroupSurfacePresentModesKHR") : instance.getProcAddr( "vkGetDeviceGroupSurfacePresentModesKHR"));\r
+ vkGetDeviceMemoryCommitment = PFN_vkGetDeviceMemoryCommitment(device ? device.getProcAddr( "vkGetDeviceMemoryCommitment") : instance.getProcAddr( "vkGetDeviceMemoryCommitment"));\r
+ vkGetDeviceProcAddr = PFN_vkGetDeviceProcAddr(device ? device.getProcAddr( "vkGetDeviceProcAddr") : instance.getProcAddr( "vkGetDeviceProcAddr"));\r
+ vkGetDeviceQueue = PFN_vkGetDeviceQueue(device ? device.getProcAddr( "vkGetDeviceQueue") : instance.getProcAddr( "vkGetDeviceQueue"));\r
+ vkGetDeviceQueue2 = PFN_vkGetDeviceQueue2(device ? device.getProcAddr( "vkGetDeviceQueue2") : instance.getProcAddr( "vkGetDeviceQueue2"));\r
+ vkGetDisplayModePropertiesKHR = PFN_vkGetDisplayModePropertiesKHR(device ? device.getProcAddr( "vkGetDisplayModePropertiesKHR") : instance.getProcAddr( "vkGetDisplayModePropertiesKHR"));\r
+ vkGetDisplayPlaneCapabilitiesKHR = PFN_vkGetDisplayPlaneCapabilitiesKHR(device ? device.getProcAddr( "vkGetDisplayPlaneCapabilitiesKHR") : instance.getProcAddr( "vkGetDisplayPlaneCapabilitiesKHR"));\r
+ vkGetDisplayPlaneSupportedDisplaysKHR = PFN_vkGetDisplayPlaneSupportedDisplaysKHR(device ? device.getProcAddr( "vkGetDisplayPlaneSupportedDisplaysKHR") : instance.getProcAddr( "vkGetDisplayPlaneSupportedDisplaysKHR"));\r
+ vkGetEventStatus = PFN_vkGetEventStatus(device ? device.getProcAddr( "vkGetEventStatus") : instance.getProcAddr( "vkGetEventStatus"));\r
+ vkGetFenceFdKHR = PFN_vkGetFenceFdKHR(device ? device.getProcAddr( "vkGetFenceFdKHR") : instance.getProcAddr( "vkGetFenceFdKHR"));\r
+ vkGetFenceStatus = PFN_vkGetFenceStatus(device ? device.getProcAddr( "vkGetFenceStatus") : instance.getProcAddr( "vkGetFenceStatus"));\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkGetFenceWin32HandleKHR = PFN_vkGetFenceWin32HandleKHR(device ? device.getProcAddr( "vkGetFenceWin32HandleKHR") : instance.getProcAddr( "vkGetFenceWin32HandleKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ vkGetImageMemoryRequirements = PFN_vkGetImageMemoryRequirements(device ? device.getProcAddr( "vkGetImageMemoryRequirements") : instance.getProcAddr( "vkGetImageMemoryRequirements"));\r
+ vkGetImageMemoryRequirements2 = PFN_vkGetImageMemoryRequirements2(device ? device.getProcAddr( "vkGetImageMemoryRequirements2") : instance.getProcAddr( "vkGetImageMemoryRequirements2"));\r
+ vkGetImageMemoryRequirements2KHR = PFN_vkGetImageMemoryRequirements2KHR(device ? device.getProcAddr( "vkGetImageMemoryRequirements2KHR") : instance.getProcAddr( "vkGetImageMemoryRequirements2KHR"));\r
+ vkGetImageSparseMemoryRequirements = PFN_vkGetImageSparseMemoryRequirements(device ? device.getProcAddr( "vkGetImageSparseMemoryRequirements") : instance.getProcAddr( "vkGetImageSparseMemoryRequirements"));\r
+ vkGetImageSparseMemoryRequirements2 = PFN_vkGetImageSparseMemoryRequirements2(device ? device.getProcAddr( "vkGetImageSparseMemoryRequirements2") : instance.getProcAddr( "vkGetImageSparseMemoryRequirements2"));\r
+ vkGetImageSparseMemoryRequirements2KHR = PFN_vkGetImageSparseMemoryRequirements2KHR(device ? device.getProcAddr( "vkGetImageSparseMemoryRequirements2KHR") : instance.getProcAddr( "vkGetImageSparseMemoryRequirements2KHR"));\r
+ vkGetImageSubresourceLayout = PFN_vkGetImageSubresourceLayout(device ? device.getProcAddr( "vkGetImageSubresourceLayout") : instance.getProcAddr( "vkGetImageSubresourceLayout"));\r
+ vkGetInstanceProcAddr = PFN_vkGetInstanceProcAddr(instance.getProcAddr( "vkGetInstanceProcAddr"));\r
+#ifdef VK_USE_PLATFORM_ANDROID_ANDROID\r
+ vkGetMemoryAndroidHardwareBufferANDROID = PFN_vkGetMemoryAndroidHardwareBufferANDROID(device ? device.getProcAddr( "vkGetMemoryAndroidHardwareBufferANDROID") : instance.getProcAddr( "vkGetMemoryAndroidHardwareBufferANDROID"));\r
+#endif /*VK_USE_PLATFORM_ANDROID_ANDROID*/\r
+ vkGetMemoryFdKHR = PFN_vkGetMemoryFdKHR(device ? device.getProcAddr( "vkGetMemoryFdKHR") : instance.getProcAddr( "vkGetMemoryFdKHR"));\r
+ vkGetMemoryFdPropertiesKHR = PFN_vkGetMemoryFdPropertiesKHR(device ? device.getProcAddr( "vkGetMemoryFdPropertiesKHR") : instance.getProcAddr( "vkGetMemoryFdPropertiesKHR"));\r
+ vkGetMemoryHostPointerPropertiesEXT = PFN_vkGetMemoryHostPointerPropertiesEXT(device ? device.getProcAddr( "vkGetMemoryHostPointerPropertiesEXT") : instance.getProcAddr( "vkGetMemoryHostPointerPropertiesEXT"));\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkGetMemoryWin32HandleKHR = PFN_vkGetMemoryWin32HandleKHR(device ? device.getProcAddr( "vkGetMemoryWin32HandleKHR") : instance.getProcAddr( "vkGetMemoryWin32HandleKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_NV\r
+ vkGetMemoryWin32HandleNV = PFN_vkGetMemoryWin32HandleNV(device ? device.getProcAddr( "vkGetMemoryWin32HandleNV") : instance.getProcAddr( "vkGetMemoryWin32HandleNV"));\r
+#endif /*VK_USE_PLATFORM_WIN32_NV*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkGetMemoryWin32HandlePropertiesKHR = PFN_vkGetMemoryWin32HandlePropertiesKHR(device ? device.getProcAddr( "vkGetMemoryWin32HandlePropertiesKHR") : instance.getProcAddr( "vkGetMemoryWin32HandlePropertiesKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ vkGetPastPresentationTimingGOOGLE = PFN_vkGetPastPresentationTimingGOOGLE(device ? device.getProcAddr( "vkGetPastPresentationTimingGOOGLE") : instance.getProcAddr( "vkGetPastPresentationTimingGOOGLE"));\r
+ vkGetPhysicalDeviceDisplayPlanePropertiesKHR = PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceDisplayPlanePropertiesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceDisplayPlanePropertiesKHR"));\r
+ vkGetPhysicalDeviceDisplayPropertiesKHR = PFN_vkGetPhysicalDeviceDisplayPropertiesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceDisplayPropertiesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceDisplayPropertiesKHR"));\r
+ vkGetPhysicalDeviceExternalBufferProperties = PFN_vkGetPhysicalDeviceExternalBufferProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalBufferProperties") : instance.getProcAddr( "vkGetPhysicalDeviceExternalBufferProperties"));\r
+ vkGetPhysicalDeviceExternalBufferPropertiesKHR = PFN_vkGetPhysicalDeviceExternalBufferPropertiesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalBufferPropertiesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceExternalBufferPropertiesKHR"));\r
+ vkGetPhysicalDeviceExternalFenceProperties = PFN_vkGetPhysicalDeviceExternalFenceProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalFenceProperties") : instance.getProcAddr( "vkGetPhysicalDeviceExternalFenceProperties"));\r
+ vkGetPhysicalDeviceExternalFencePropertiesKHR = PFN_vkGetPhysicalDeviceExternalFencePropertiesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalFencePropertiesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceExternalFencePropertiesKHR"));\r
+ vkGetPhysicalDeviceExternalImageFormatPropertiesNV = PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalImageFormatPropertiesNV") : instance.getProcAddr( "vkGetPhysicalDeviceExternalImageFormatPropertiesNV"));\r
+ vkGetPhysicalDeviceExternalSemaphoreProperties = PFN_vkGetPhysicalDeviceExternalSemaphoreProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalSemaphoreProperties") : instance.getProcAddr( "vkGetPhysicalDeviceExternalSemaphoreProperties"));\r
+ vkGetPhysicalDeviceExternalSemaphorePropertiesKHR = PFN_vkGetPhysicalDeviceExternalSemaphorePropertiesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceExternalSemaphorePropertiesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceExternalSemaphorePropertiesKHR"));\r
+ vkGetPhysicalDeviceFeatures = PFN_vkGetPhysicalDeviceFeatures(device ? device.getProcAddr( "vkGetPhysicalDeviceFeatures") : instance.getProcAddr( "vkGetPhysicalDeviceFeatures"));\r
+ vkGetPhysicalDeviceFeatures2 = PFN_vkGetPhysicalDeviceFeatures2(device ? device.getProcAddr( "vkGetPhysicalDeviceFeatures2") : instance.getProcAddr( "vkGetPhysicalDeviceFeatures2"));\r
+ vkGetPhysicalDeviceFeatures2KHR = PFN_vkGetPhysicalDeviceFeatures2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceFeatures2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceFeatures2KHR"));\r
+ vkGetPhysicalDeviceFormatProperties = PFN_vkGetPhysicalDeviceFormatProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceFormatProperties") : instance.getProcAddr( "vkGetPhysicalDeviceFormatProperties"));\r
+ vkGetPhysicalDeviceFormatProperties2 = PFN_vkGetPhysicalDeviceFormatProperties2(device ? device.getProcAddr( "vkGetPhysicalDeviceFormatProperties2") : instance.getProcAddr( "vkGetPhysicalDeviceFormatProperties2"));\r
+ vkGetPhysicalDeviceFormatProperties2KHR = PFN_vkGetPhysicalDeviceFormatProperties2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceFormatProperties2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceFormatProperties2KHR"));\r
+ vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX = PFN_vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX(device ? device.getProcAddr( "vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX") : instance.getProcAddr( "vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX"));\r
+ vkGetPhysicalDeviceImageFormatProperties = PFN_vkGetPhysicalDeviceImageFormatProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceImageFormatProperties") : instance.getProcAddr( "vkGetPhysicalDeviceImageFormatProperties"));\r
+ vkGetPhysicalDeviceImageFormatProperties2 = PFN_vkGetPhysicalDeviceImageFormatProperties2(device ? device.getProcAddr( "vkGetPhysicalDeviceImageFormatProperties2") : instance.getProcAddr( "vkGetPhysicalDeviceImageFormatProperties2"));\r
+ vkGetPhysicalDeviceImageFormatProperties2KHR = PFN_vkGetPhysicalDeviceImageFormatProperties2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceImageFormatProperties2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceImageFormatProperties2KHR"));\r
+ vkGetPhysicalDeviceMemoryProperties = PFN_vkGetPhysicalDeviceMemoryProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceMemoryProperties") : instance.getProcAddr( "vkGetPhysicalDeviceMemoryProperties"));\r
+ vkGetPhysicalDeviceMemoryProperties2 = PFN_vkGetPhysicalDeviceMemoryProperties2(device ? device.getProcAddr( "vkGetPhysicalDeviceMemoryProperties2") : instance.getProcAddr( "vkGetPhysicalDeviceMemoryProperties2"));\r
+ vkGetPhysicalDeviceMemoryProperties2KHR = PFN_vkGetPhysicalDeviceMemoryProperties2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceMemoryProperties2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceMemoryProperties2KHR"));\r
+#ifdef VK_USE_PLATFORM_MIR_KHR\r
+ vkGetPhysicalDeviceMirPresentationSupportKHR = PFN_vkGetPhysicalDeviceMirPresentationSupportKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceMirPresentationSupportKHR") : instance.getProcAddr( "vkGetPhysicalDeviceMirPresentationSupportKHR"));\r
+#endif /*VK_USE_PLATFORM_MIR_KHR*/\r
+ vkGetPhysicalDeviceMultisamplePropertiesEXT = PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT(device ? device.getProcAddr( "vkGetPhysicalDeviceMultisamplePropertiesEXT") : instance.getProcAddr( "vkGetPhysicalDeviceMultisamplePropertiesEXT"));\r
+ vkGetPhysicalDevicePresentRectanglesKHR = PFN_vkGetPhysicalDevicePresentRectanglesKHR(device ? device.getProcAddr( "vkGetPhysicalDevicePresentRectanglesKHR") : instance.getProcAddr( "vkGetPhysicalDevicePresentRectanglesKHR"));\r
+ vkGetPhysicalDeviceProperties = PFN_vkGetPhysicalDeviceProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceProperties") : instance.getProcAddr( "vkGetPhysicalDeviceProperties"));\r
+ vkGetPhysicalDeviceProperties2 = PFN_vkGetPhysicalDeviceProperties2(device ? device.getProcAddr( "vkGetPhysicalDeviceProperties2") : instance.getProcAddr( "vkGetPhysicalDeviceProperties2"));\r
+ vkGetPhysicalDeviceProperties2KHR = PFN_vkGetPhysicalDeviceProperties2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceProperties2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceProperties2KHR"));\r
+ vkGetPhysicalDeviceQueueFamilyProperties = PFN_vkGetPhysicalDeviceQueueFamilyProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceQueueFamilyProperties") : instance.getProcAddr( "vkGetPhysicalDeviceQueueFamilyProperties"));\r
+ vkGetPhysicalDeviceQueueFamilyProperties2 = PFN_vkGetPhysicalDeviceQueueFamilyProperties2(device ? device.getProcAddr( "vkGetPhysicalDeviceQueueFamilyProperties2") : instance.getProcAddr( "vkGetPhysicalDeviceQueueFamilyProperties2"));\r
+ vkGetPhysicalDeviceQueueFamilyProperties2KHR = PFN_vkGetPhysicalDeviceQueueFamilyProperties2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceQueueFamilyProperties2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceQueueFamilyProperties2KHR"));\r
+ vkGetPhysicalDeviceSparseImageFormatProperties = PFN_vkGetPhysicalDeviceSparseImageFormatProperties(device ? device.getProcAddr( "vkGetPhysicalDeviceSparseImageFormatProperties") : instance.getProcAddr( "vkGetPhysicalDeviceSparseImageFormatProperties"));\r
+ vkGetPhysicalDeviceSparseImageFormatProperties2 = PFN_vkGetPhysicalDeviceSparseImageFormatProperties2(device ? device.getProcAddr( "vkGetPhysicalDeviceSparseImageFormatProperties2") : instance.getProcAddr( "vkGetPhysicalDeviceSparseImageFormatProperties2"));\r
+ vkGetPhysicalDeviceSparseImageFormatProperties2KHR = PFN_vkGetPhysicalDeviceSparseImageFormatProperties2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSparseImageFormatProperties2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceSparseImageFormatProperties2KHR"));\r
+ vkGetPhysicalDeviceSurfaceCapabilities2EXT = PFN_vkGetPhysicalDeviceSurfaceCapabilities2EXT(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfaceCapabilities2EXT") : instance.getProcAddr( "vkGetPhysicalDeviceSurfaceCapabilities2EXT"));\r
+ vkGetPhysicalDeviceSurfaceCapabilities2KHR = PFN_vkGetPhysicalDeviceSurfaceCapabilities2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfaceCapabilities2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceSurfaceCapabilities2KHR"));\r
+ vkGetPhysicalDeviceSurfaceCapabilitiesKHR = PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfaceCapabilitiesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceSurfaceCapabilitiesKHR"));\r
+ vkGetPhysicalDeviceSurfaceFormats2KHR = PFN_vkGetPhysicalDeviceSurfaceFormats2KHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfaceFormats2KHR") : instance.getProcAddr( "vkGetPhysicalDeviceSurfaceFormats2KHR"));\r
+ vkGetPhysicalDeviceSurfaceFormatsKHR = PFN_vkGetPhysicalDeviceSurfaceFormatsKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfaceFormatsKHR") : instance.getProcAddr( "vkGetPhysicalDeviceSurfaceFormatsKHR"));\r
+ vkGetPhysicalDeviceSurfacePresentModesKHR = PFN_vkGetPhysicalDeviceSurfacePresentModesKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfacePresentModesKHR") : instance.getProcAddr( "vkGetPhysicalDeviceSurfacePresentModesKHR"));\r
+ vkGetPhysicalDeviceSurfaceSupportKHR = PFN_vkGetPhysicalDeviceSurfaceSupportKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceSurfaceSupportKHR") : instance.getProcAddr( "vkGetPhysicalDeviceSurfaceSupportKHR"));\r
+#ifdef VK_USE_PLATFORM_WAYLAND_KHR\r
+ vkGetPhysicalDeviceWaylandPresentationSupportKHR = PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceWaylandPresentationSupportKHR") : instance.getProcAddr( "vkGetPhysicalDeviceWaylandPresentationSupportKHR"));\r
+#endif /*VK_USE_PLATFORM_WAYLAND_KHR*/\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkGetPhysicalDeviceWin32PresentationSupportKHR = PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceWin32PresentationSupportKHR") : instance.getProcAddr( "vkGetPhysicalDeviceWin32PresentationSupportKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+#ifdef VK_USE_PLATFORM_XCB_KHR\r
+ vkGetPhysicalDeviceXcbPresentationSupportKHR = PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceXcbPresentationSupportKHR") : instance.getProcAddr( "vkGetPhysicalDeviceXcbPresentationSupportKHR"));\r
+#endif /*VK_USE_PLATFORM_XCB_KHR*/\r
+#ifdef VK_USE_PLATFORM_XLIB_KHR\r
+ vkGetPhysicalDeviceXlibPresentationSupportKHR = PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR(device ? device.getProcAddr( "vkGetPhysicalDeviceXlibPresentationSupportKHR") : instance.getProcAddr( "vkGetPhysicalDeviceXlibPresentationSupportKHR"));\r
+#endif /*VK_USE_PLATFORM_XLIB_KHR*/\r
+ vkGetPipelineCacheData = PFN_vkGetPipelineCacheData(device ? device.getProcAddr( "vkGetPipelineCacheData") : instance.getProcAddr( "vkGetPipelineCacheData"));\r
+ vkGetQueryPoolResults = PFN_vkGetQueryPoolResults(device ? device.getProcAddr( "vkGetQueryPoolResults") : instance.getProcAddr( "vkGetQueryPoolResults"));\r
+#ifdef VK_USE_PLATFORM_XLIB_XRANDR_NV\r
+ vkGetRandROutputDisplayEXT = PFN_vkGetRandROutputDisplayEXT(device ? device.getProcAddr( "vkGetRandROutputDisplayEXT") : instance.getProcAddr( "vkGetRandROutputDisplayEXT"));\r
+#endif /*VK_USE_PLATFORM_XLIB_XRANDR_NV*/\r
+ vkGetRefreshCycleDurationGOOGLE = PFN_vkGetRefreshCycleDurationGOOGLE(device ? device.getProcAddr( "vkGetRefreshCycleDurationGOOGLE") : instance.getProcAddr( "vkGetRefreshCycleDurationGOOGLE"));\r
+ vkGetRenderAreaGranularity = PFN_vkGetRenderAreaGranularity(device ? device.getProcAddr( "vkGetRenderAreaGranularity") : instance.getProcAddr( "vkGetRenderAreaGranularity"));\r
+ vkGetSemaphoreFdKHR = PFN_vkGetSemaphoreFdKHR(device ? device.getProcAddr( "vkGetSemaphoreFdKHR") : instance.getProcAddr( "vkGetSemaphoreFdKHR"));\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkGetSemaphoreWin32HandleKHR = PFN_vkGetSemaphoreWin32HandleKHR(device ? device.getProcAddr( "vkGetSemaphoreWin32HandleKHR") : instance.getProcAddr( "vkGetSemaphoreWin32HandleKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ vkGetShaderInfoAMD = PFN_vkGetShaderInfoAMD(device ? device.getProcAddr( "vkGetShaderInfoAMD") : instance.getProcAddr( "vkGetShaderInfoAMD"));\r
+ vkGetSwapchainCounterEXT = PFN_vkGetSwapchainCounterEXT(device ? device.getProcAddr( "vkGetSwapchainCounterEXT") : instance.getProcAddr( "vkGetSwapchainCounterEXT"));\r
+ vkGetSwapchainImagesKHR = PFN_vkGetSwapchainImagesKHR(device ? device.getProcAddr( "vkGetSwapchainImagesKHR") : instance.getProcAddr( "vkGetSwapchainImagesKHR"));\r
+ vkGetSwapchainStatusKHR = PFN_vkGetSwapchainStatusKHR(device ? device.getProcAddr( "vkGetSwapchainStatusKHR") : instance.getProcAddr( "vkGetSwapchainStatusKHR"));\r
+ vkGetValidationCacheDataEXT = PFN_vkGetValidationCacheDataEXT(device ? device.getProcAddr( "vkGetValidationCacheDataEXT") : instance.getProcAddr( "vkGetValidationCacheDataEXT"));\r
+ vkImportFenceFdKHR = PFN_vkImportFenceFdKHR(device ? device.getProcAddr( "vkImportFenceFdKHR") : instance.getProcAddr( "vkImportFenceFdKHR"));\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkImportFenceWin32HandleKHR = PFN_vkImportFenceWin32HandleKHR(device ? device.getProcAddr( "vkImportFenceWin32HandleKHR") : instance.getProcAddr( "vkImportFenceWin32HandleKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ vkImportSemaphoreFdKHR = PFN_vkImportSemaphoreFdKHR(device ? device.getProcAddr( "vkImportSemaphoreFdKHR") : instance.getProcAddr( "vkImportSemaphoreFdKHR"));\r
+#ifdef VK_USE_PLATFORM_WIN32_KHR\r
+ vkImportSemaphoreWin32HandleKHR = PFN_vkImportSemaphoreWin32HandleKHR(device ? device.getProcAddr( "vkImportSemaphoreWin32HandleKHR") : instance.getProcAddr( "vkImportSemaphoreWin32HandleKHR"));\r
+#endif /*VK_USE_PLATFORM_WIN32_KHR*/\r
+ vkInvalidateMappedMemoryRanges = PFN_vkInvalidateMappedMemoryRanges(device ? device.getProcAddr( "vkInvalidateMappedMemoryRanges") : instance.getProcAddr( "vkInvalidateMappedMemoryRanges"));\r
+ vkMapMemory = PFN_vkMapMemory(device ? device.getProcAddr( "vkMapMemory") : instance.getProcAddr( "vkMapMemory"));\r
+ vkMergePipelineCaches = PFN_vkMergePipelineCaches(device ? device.getProcAddr( "vkMergePipelineCaches") : instance.getProcAddr( "vkMergePipelineCaches"));\r
+ vkMergeValidationCachesEXT = PFN_vkMergeValidationCachesEXT(device ? device.getProcAddr( "vkMergeValidationCachesEXT") : instance.getProcAddr( "vkMergeValidationCachesEXT"));\r
+ vkQueueBeginDebugUtilsLabelEXT = PFN_vkQueueBeginDebugUtilsLabelEXT(device ? device.getProcAddr( "vkQueueBeginDebugUtilsLabelEXT") : instance.getProcAddr( "vkQueueBeginDebugUtilsLabelEXT"));\r
+ vkQueueBindSparse = PFN_vkQueueBindSparse(device ? device.getProcAddr( "vkQueueBindSparse") : instance.getProcAddr( "vkQueueBindSparse"));\r
+ vkQueueEndDebugUtilsLabelEXT = PFN_vkQueueEndDebugUtilsLabelEXT(device ? device.getProcAddr( "vkQueueEndDebugUtilsLabelEXT") : instance.getProcAddr( "vkQueueEndDebugUtilsLabelEXT"));\r
+ vkQueueInsertDebugUtilsLabelEXT = PFN_vkQueueInsertDebugUtilsLabelEXT(device ? device.getProcAddr( "vkQueueInsertDebugUtilsLabelEXT") : instance.getProcAddr( "vkQueueInsertDebugUtilsLabelEXT"));\r
+ vkQueuePresentKHR = PFN_vkQueuePresentKHR(device ? device.getProcAddr( "vkQueuePresentKHR") : instance.getProcAddr( "vkQueuePresentKHR"));\r
+ vkQueueSubmit = PFN_vkQueueSubmit(device ? device.getProcAddr( "vkQueueSubmit") : instance.getProcAddr( "vkQueueSubmit"));\r
+ vkQueueWaitIdle = PFN_vkQueueWaitIdle(device ? device.getProcAddr( "vkQueueWaitIdle") : instance.getProcAddr( "vkQueueWaitIdle"));\r
+ vkRegisterDeviceEventEXT = PFN_vkRegisterDeviceEventEXT(device ? device.getProcAddr( "vkRegisterDeviceEventEXT") : instance.getProcAddr( "vkRegisterDeviceEventEXT"));\r
+ vkRegisterDisplayEventEXT = PFN_vkRegisterDisplayEventEXT(device ? device.getProcAddr( "vkRegisterDisplayEventEXT") : instance.getProcAddr( "vkRegisterDisplayEventEXT"));\r
+ vkRegisterObjectsNVX = PFN_vkRegisterObjectsNVX(device ? device.getProcAddr( "vkRegisterObjectsNVX") : instance.getProcAddr( "vkRegisterObjectsNVX"));\r
+ vkReleaseDisplayEXT = PFN_vkReleaseDisplayEXT(device ? device.getProcAddr( "vkReleaseDisplayEXT") : instance.getProcAddr( "vkReleaseDisplayEXT"));\r
+ vkResetCommandBuffer = PFN_vkResetCommandBuffer(device ? device.getProcAddr( "vkResetCommandBuffer") : instance.getProcAddr( "vkResetCommandBuffer"));\r
+ vkResetCommandPool = PFN_vkResetCommandPool(device ? device.getProcAddr( "vkResetCommandPool") : instance.getProcAddr( "vkResetCommandPool"));\r
+ vkResetDescriptorPool = PFN_vkResetDescriptorPool(device ? device.getProcAddr( "vkResetDescriptorPool") : instance.getProcAddr( "vkResetDescriptorPool"));\r
+ vkResetEvent = PFN_vkResetEvent(device ? device.getProcAddr( "vkResetEvent") : instance.getProcAddr( "vkResetEvent"));\r
+ vkResetFences = PFN_vkResetFences(device ? device.getProcAddr( "vkResetFences") : instance.getProcAddr( "vkResetFences"));\r
+ vkSetDebugUtilsObjectNameEXT = PFN_vkSetDebugUtilsObjectNameEXT(device ? device.getProcAddr( "vkSetDebugUtilsObjectNameEXT") : instance.getProcAddr( "vkSetDebugUtilsObjectNameEXT"));\r
+ vkSetDebugUtilsObjectTagEXT = PFN_vkSetDebugUtilsObjectTagEXT(device ? device.getProcAddr( "vkSetDebugUtilsObjectTagEXT") : instance.getProcAddr( "vkSetDebugUtilsObjectTagEXT"));\r
+ vkSetEvent = PFN_vkSetEvent(device ? device.getProcAddr( "vkSetEvent") : instance.getProcAddr( "vkSetEvent"));\r
+ vkSetHdrMetadataEXT = PFN_vkSetHdrMetadataEXT(device ? device.getProcAddr( "vkSetHdrMetadataEXT") : instance.getProcAddr( "vkSetHdrMetadataEXT"));\r
+ vkSubmitDebugUtilsMessageEXT = PFN_vkSubmitDebugUtilsMessageEXT(instance.getProcAddr( "vkSubmitDebugUtilsMessageEXT"));\r
+ vkTrimCommandPool = PFN_vkTrimCommandPool(device ? device.getProcAddr( "vkTrimCommandPool") : instance.getProcAddr( "vkTrimCommandPool"));\r
+ vkTrimCommandPoolKHR = PFN_vkTrimCommandPoolKHR(device ? device.getProcAddr( "vkTrimCommandPoolKHR") : instance.getProcAddr( "vkTrimCommandPoolKHR"));\r
+ vkUnmapMemory = PFN_vkUnmapMemory(device ? device.getProcAddr( "vkUnmapMemory") : instance.getProcAddr( "vkUnmapMemory"));\r
+ vkUnregisterObjectsNVX = PFN_vkUnregisterObjectsNVX(device ? device.getProcAddr( "vkUnregisterObjectsNVX") : instance.getProcAddr( "vkUnregisterObjectsNVX"));\r
+ vkUpdateDescriptorSetWithTemplate = PFN_vkUpdateDescriptorSetWithTemplate(device ? device.getProcAddr( "vkUpdateDescriptorSetWithTemplate") : instance.getProcAddr( "vkUpdateDescriptorSetWithTemplate"));\r
+ vkUpdateDescriptorSetWithTemplateKHR = PFN_vkUpdateDescriptorSetWithTemplateKHR(device ? device.getProcAddr( "vkUpdateDescriptorSetWithTemplateKHR") : instance.getProcAddr( "vkUpdateDescriptorSetWithTemplateKHR"));\r
+ vkUpdateDescriptorSets = PFN_vkUpdateDescriptorSets(device ? device.getProcAddr( "vkUpdateDescriptorSets") : instance.getProcAddr( "vkUpdateDescriptorSets"));\r
+ vkWaitForFences = PFN_vkWaitForFences(device ? device.getProcAddr( "vkWaitForFences") : instance.getProcAddr( "vkWaitForFences"));\r
+ }\r
+ };\r
+} // namespace VULKAN_HPP_NAMESPACE\r
+\r
+#endif\r
--- /dev/null
+#ifndef VULKAN_ANDROID_H_
+#define VULKAN_ANDROID_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_KHR_android_surface 1
+struct ANativeWindow;
+
+#define VK_KHR_ANDROID_SURFACE_SPEC_VERSION 6
+#define VK_KHR_ANDROID_SURFACE_EXTENSION_NAME "VK_KHR_android_surface"
+
+typedef VkFlags VkAndroidSurfaceCreateFlagsKHR;
+
+typedef struct VkAndroidSurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkAndroidSurfaceCreateFlagsKHR flags;
+ struct ANativeWindow* window;
+} VkAndroidSurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateAndroidSurfaceKHR)(VkInstance instance, const VkAndroidSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateAndroidSurfaceKHR(
+ VkInstance instance,
+ const VkAndroidSurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+#endif
+
+#define VK_ANDROID_external_memory_android_hardware_buffer 1
+struct AHardwareBuffer;
+
+#define VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_SPEC_VERSION 3
+#define VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_EXTENSION_NAME "VK_ANDROID_external_memory_android_hardware_buffer"
+
+typedef struct VkAndroidHardwareBufferUsageANDROID {
+ VkStructureType sType;
+ void* pNext;
+ uint64_t androidHardwareBufferUsage;
+} VkAndroidHardwareBufferUsageANDROID;
+
+typedef struct VkAndroidHardwareBufferPropertiesANDROID {
+ VkStructureType sType;
+ void* pNext;
+ VkDeviceSize allocationSize;
+ uint32_t memoryTypeBits;
+} VkAndroidHardwareBufferPropertiesANDROID;
+
+typedef struct VkAndroidHardwareBufferFormatPropertiesANDROID {
+ VkStructureType sType;
+ void* pNext;
+ VkFormat format;
+ uint64_t externalFormat;
+ VkFormatFeatureFlags formatFeatures;
+ VkComponentMapping samplerYcbcrConversionComponents;
+ VkSamplerYcbcrModelConversion suggestedYcbcrModel;
+ VkSamplerYcbcrRange suggestedYcbcrRange;
+ VkChromaLocation suggestedXChromaOffset;
+ VkChromaLocation suggestedYChromaOffset;
+} VkAndroidHardwareBufferFormatPropertiesANDROID;
+
+typedef struct VkImportAndroidHardwareBufferInfoANDROID {
+ VkStructureType sType;
+ const void* pNext;
+ struct AHardwareBuffer* buffer;
+} VkImportAndroidHardwareBufferInfoANDROID;
+
+typedef struct VkMemoryGetAndroidHardwareBufferInfoANDROID {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceMemory memory;
+} VkMemoryGetAndroidHardwareBufferInfoANDROID;
+
+typedef struct VkExternalFormatANDROID {
+ VkStructureType sType;
+ void* pNext;
+ uint64_t externalFormat;
+} VkExternalFormatANDROID;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetAndroidHardwareBufferPropertiesANDROID)(VkDevice device, const struct AHardwareBuffer* buffer, VkAndroidHardwareBufferPropertiesANDROID* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryAndroidHardwareBufferANDROID)(VkDevice device, const VkMemoryGetAndroidHardwareBufferInfoANDROID* pInfo, struct AHardwareBuffer** pBuffer);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetAndroidHardwareBufferPropertiesANDROID(
+ VkDevice device,
+ const struct AHardwareBuffer* buffer,
+ VkAndroidHardwareBufferPropertiesANDROID* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryAndroidHardwareBufferANDROID(
+ VkDevice device,
+ const VkMemoryGetAndroidHardwareBufferInfoANDROID* pInfo,
+ struct AHardwareBuffer** pBuffer);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_CORE_H_
+#define VULKAN_CORE_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_VERSION_1_0 1
+#include "vk_platform.h"
+
+#define VK_MAKE_VERSION(major, minor, patch) \
+ (((major) << 22) | ((minor) << 12) | (patch))
+
+// DEPRECATED: This define has been removed. Specific version defines (e.g. VK_API_VERSION_1_0), or the VK_MAKE_VERSION macro, should be used instead.
+//#define VK_API_VERSION VK_MAKE_VERSION(1, 0, 0) // Patch version should always be set to 0
+
+// Vulkan 1.0 version number
+#define VK_API_VERSION_1_0 VK_MAKE_VERSION(1, 0, 0)// Patch version should always be set to 0
+
+#define VK_VERSION_MAJOR(version) ((uint32_t)(version) >> 22)
+#define VK_VERSION_MINOR(version) (((uint32_t)(version) >> 12) & 0x3ff)
+#define VK_VERSION_PATCH(version) ((uint32_t)(version) & 0xfff)
+// Version of this file
+#define VK_HEADER_VERSION 74
+
+
+#define VK_NULL_HANDLE 0
+
+
+
+#define VK_DEFINE_HANDLE(object) typedef struct object##_T* object;
+
+
+#if !defined(VK_DEFINE_NON_DISPATCHABLE_HANDLE)
+#if defined(__LP64__) || defined(_WIN64) || (defined(__x86_64__) && !defined(__ILP32__) ) || defined(_M_X64) || defined(__ia64) || defined (_M_IA64) || defined(__aarch64__) || defined(__powerpc64__)
+ #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef struct object##_T *object;
+#else
+ #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef uint64_t object;
+#endif
+#endif
+
+
+
+typedef uint32_t VkFlags;
+typedef uint32_t VkBool32;
+typedef uint64_t VkDeviceSize;
+typedef uint32_t VkSampleMask;
+
+VK_DEFINE_HANDLE(VkInstance)
+VK_DEFINE_HANDLE(VkPhysicalDevice)
+VK_DEFINE_HANDLE(VkDevice)
+VK_DEFINE_HANDLE(VkQueue)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSemaphore)
+VK_DEFINE_HANDLE(VkCommandBuffer)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkFence)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDeviceMemory)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBuffer)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkImage)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkEvent)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkQueryPool)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBufferView)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkImageView)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkShaderModule)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipelineCache)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipelineLayout)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkRenderPass)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkPipeline)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorSetLayout)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSampler)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorPool)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorSet)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkFramebuffer)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkCommandPool)
+
+#define VK_LOD_CLAMP_NONE 1000.0f
+#define VK_REMAINING_MIP_LEVELS (~0U)
+#define VK_REMAINING_ARRAY_LAYERS (~0U)
+#define VK_WHOLE_SIZE (~0ULL)
+#define VK_ATTACHMENT_UNUSED (~0U)
+#define VK_TRUE 1
+#define VK_FALSE 0
+#define VK_QUEUE_FAMILY_IGNORED (~0U)
+#define VK_SUBPASS_EXTERNAL (~0U)
+#define VK_MAX_PHYSICAL_DEVICE_NAME_SIZE 256
+#define VK_UUID_SIZE 16
+#define VK_MAX_MEMORY_TYPES 32
+#define VK_MAX_MEMORY_HEAPS 16
+#define VK_MAX_EXTENSION_NAME_SIZE 256
+#define VK_MAX_DESCRIPTION_SIZE 256
+
+
+typedef enum VkPipelineCacheHeaderVersion {
+ VK_PIPELINE_CACHE_HEADER_VERSION_ONE = 1,
+ VK_PIPELINE_CACHE_HEADER_VERSION_BEGIN_RANGE = VK_PIPELINE_CACHE_HEADER_VERSION_ONE,
+ VK_PIPELINE_CACHE_HEADER_VERSION_END_RANGE = VK_PIPELINE_CACHE_HEADER_VERSION_ONE,
+ VK_PIPELINE_CACHE_HEADER_VERSION_RANGE_SIZE = (VK_PIPELINE_CACHE_HEADER_VERSION_ONE - VK_PIPELINE_CACHE_HEADER_VERSION_ONE + 1),
+ VK_PIPELINE_CACHE_HEADER_VERSION_MAX_ENUM = 0x7FFFFFFF
+} VkPipelineCacheHeaderVersion;
+
+typedef enum VkResult {
+ VK_SUCCESS = 0,
+ VK_NOT_READY = 1,
+ VK_TIMEOUT = 2,
+ VK_EVENT_SET = 3,
+ VK_EVENT_RESET = 4,
+ VK_INCOMPLETE = 5,
+ VK_ERROR_OUT_OF_HOST_MEMORY = -1,
+ VK_ERROR_OUT_OF_DEVICE_MEMORY = -2,
+ VK_ERROR_INITIALIZATION_FAILED = -3,
+ VK_ERROR_DEVICE_LOST = -4,
+ VK_ERROR_MEMORY_MAP_FAILED = -5,
+ VK_ERROR_LAYER_NOT_PRESENT = -6,
+ VK_ERROR_EXTENSION_NOT_PRESENT = -7,
+ VK_ERROR_FEATURE_NOT_PRESENT = -8,
+ VK_ERROR_INCOMPATIBLE_DRIVER = -9,
+ VK_ERROR_TOO_MANY_OBJECTS = -10,
+ VK_ERROR_FORMAT_NOT_SUPPORTED = -11,
+ VK_ERROR_FRAGMENTED_POOL = -12,
+ VK_ERROR_OUT_OF_POOL_MEMORY = -1000069000,
+ VK_ERROR_INVALID_EXTERNAL_HANDLE = -1000072003,
+ VK_ERROR_SURFACE_LOST_KHR = -1000000000,
+ VK_ERROR_NATIVE_WINDOW_IN_USE_KHR = -1000000001,
+ VK_SUBOPTIMAL_KHR = 1000001003,
+ VK_ERROR_OUT_OF_DATE_KHR = -1000001004,
+ VK_ERROR_INCOMPATIBLE_DISPLAY_KHR = -1000003001,
+ VK_ERROR_VALIDATION_FAILED_EXT = -1000011001,
+ VK_ERROR_INVALID_SHADER_NV = -1000012000,
+ VK_ERROR_FRAGMENTATION_EXT = -1000161000,
+ VK_ERROR_NOT_PERMITTED_EXT = -1000174001,
+ VK_ERROR_OUT_OF_POOL_MEMORY_KHR = VK_ERROR_OUT_OF_POOL_MEMORY,
+ VK_ERROR_INVALID_EXTERNAL_HANDLE_KHR = VK_ERROR_INVALID_EXTERNAL_HANDLE,
+ VK_RESULT_BEGIN_RANGE = VK_ERROR_FRAGMENTED_POOL,
+ VK_RESULT_END_RANGE = VK_INCOMPLETE,
+ VK_RESULT_RANGE_SIZE = (VK_INCOMPLETE - VK_ERROR_FRAGMENTED_POOL + 1),
+ VK_RESULT_MAX_ENUM = 0x7FFFFFFF
+} VkResult;
+
+typedef enum VkStructureType {
+ VK_STRUCTURE_TYPE_APPLICATION_INFO = 0,
+ VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO = 1,
+ VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO = 2,
+ VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO = 3,
+ VK_STRUCTURE_TYPE_SUBMIT_INFO = 4,
+ VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO = 5,
+ VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE = 6,
+ VK_STRUCTURE_TYPE_BIND_SPARSE_INFO = 7,
+ VK_STRUCTURE_TYPE_FENCE_CREATE_INFO = 8,
+ VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO = 9,
+ VK_STRUCTURE_TYPE_EVENT_CREATE_INFO = 10,
+ VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO = 11,
+ VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO = 12,
+ VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO = 13,
+ VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO = 14,
+ VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO = 15,
+ VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO = 16,
+ VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO = 17,
+ VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO = 18,
+ VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO = 19,
+ VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO = 20,
+ VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO = 21,
+ VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO = 22,
+ VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO = 23,
+ VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO = 24,
+ VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO = 25,
+ VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO = 26,
+ VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO = 27,
+ VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO = 28,
+ VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO = 29,
+ VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO = 30,
+ VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO = 31,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO = 32,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO = 33,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO = 34,
+ VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET = 35,
+ VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET = 36,
+ VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO = 37,
+ VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO = 38,
+ VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO = 39,
+ VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO = 40,
+ VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO = 41,
+ VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO = 42,
+ VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO = 43,
+ VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER = 44,
+ VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER = 45,
+ VK_STRUCTURE_TYPE_MEMORY_BARRIER = 46,
+ VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO = 47,
+ VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO = 48,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES = 1000094000,
+ VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO = 1000157000,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO = 1000157001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES = 1000083000,
+ VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS = 1000127000,
+ VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO = 1000127001,
+ VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO = 1000060000,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO = 1000060003,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO = 1000060004,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO = 1000060005,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO = 1000060006,
+ VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO = 1000060013,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO = 1000060014,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES = 1000070000,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO = 1000070001,
+ VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2 = 1000146000,
+ VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2 = 1000146001,
+ VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2 = 1000146002,
+ VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2 = 1000146003,
+ VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2 = 1000146004,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2 = 1000059000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2 = 1000059001,
+ VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2 = 1000059002,
+ VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2 = 1000059003,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2 = 1000059004,
+ VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2 = 1000059005,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2 = 1000059006,
+ VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2 = 1000059007,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2 = 1000059008,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES = 1000117000,
+ VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO = 1000117001,
+ VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO = 1000117002,
+ VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO = 1000117003,
+ VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO = 1000053000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES = 1000053001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES = 1000053002,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES = 1000120000,
+ VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO = 1000145000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES = 1000145001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES = 1000145002,
+ VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2 = 1000145003,
+ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO = 1000156000,
+ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO = 1000156001,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO = 1000156002,
+ VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO = 1000156003,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES = 1000156004,
+ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES = 1000156005,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO = 1000085000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO = 1000071000,
+ VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES = 1000071001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO = 1000071002,
+ VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES = 1000071003,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES = 1000071004,
+ VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO = 1000072000,
+ VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO = 1000072001,
+ VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO = 1000072002,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO = 1000112000,
+ VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES = 1000112001,
+ VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO = 1000113000,
+ VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO = 1000077000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO = 1000076000,
+ VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES = 1000076001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES = 1000168000,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT = 1000168001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES = 1000063000,
+ VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR = 1000001000,
+ VK_STRUCTURE_TYPE_PRESENT_INFO_KHR = 1000001001,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR = 1000060007,
+ VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR = 1000060008,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR = 1000060009,
+ VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR = 1000060010,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR = 1000060011,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR = 1000060012,
+ VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR = 1000002000,
+ VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR = 1000002001,
+ VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR = 1000003000,
+ VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR = 1000004000,
+ VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR = 1000005000,
+ VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR = 1000006000,
+ VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR = 1000007000,
+ VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR = 1000008000,
+ VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR = 1000009000,
+ VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT = 1000011000,
+ VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD = 1000018000,
+ VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT = 1000022000,
+ VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT = 1000022001,
+ VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT = 1000022002,
+ VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV = 1000026000,
+ VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV = 1000026001,
+ VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV = 1000026002,
+ VK_STRUCTURE_TYPE_TEXTURE_LOD_GATHER_FORMAT_PROPERTIES_AMD = 1000041000,
+ VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV = 1000056000,
+ VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV = 1000056001,
+ VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV = 1000057000,
+ VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV = 1000057001,
+ VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV = 1000058000,
+ VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT = 1000061000,
+ VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN = 1000062000,
+ VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_KHR = 1000073000,
+ VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_KHR = 1000073001,
+ VK_STRUCTURE_TYPE_MEMORY_WIN32_HANDLE_PROPERTIES_KHR = 1000073002,
+ VK_STRUCTURE_TYPE_MEMORY_GET_WIN32_HANDLE_INFO_KHR = 1000073003,
+ VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR = 1000074000,
+ VK_STRUCTURE_TYPE_MEMORY_FD_PROPERTIES_KHR = 1000074001,
+ VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR = 1000074002,
+ VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_KHR = 1000075000,
+ VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR = 1000078000,
+ VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR = 1000078001,
+ VK_STRUCTURE_TYPE_D3D12_FENCE_SUBMIT_INFO_KHR = 1000078002,
+ VK_STRUCTURE_TYPE_SEMAPHORE_GET_WIN32_HANDLE_INFO_KHR = 1000078003,
+ VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR = 1000079000,
+ VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR = 1000079001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR = 1000080000,
+ VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR = 1000084000,
+ VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX = 1000086000,
+ VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX = 1000086001,
+ VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX = 1000086002,
+ VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX = 1000086003,
+ VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX = 1000086004,
+ VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX = 1000086005,
+ VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV = 1000087000,
+ VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT = 1000090000,
+ VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT = 1000091000,
+ VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT = 1000091001,
+ VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT = 1000091002,
+ VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT = 1000091003,
+ VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE = 1000092000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX = 1000097000,
+ VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV = 1000098000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT = 1000099000,
+ VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT = 1000099001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT = 1000101000,
+ VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT = 1000101001,
+ VK_STRUCTURE_TYPE_HDR_METADATA_EXT = 1000105000,
+ VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR = 1000111000,
+ VK_STRUCTURE_TYPE_IMPORT_FENCE_WIN32_HANDLE_INFO_KHR = 1000114000,
+ VK_STRUCTURE_TYPE_EXPORT_FENCE_WIN32_HANDLE_INFO_KHR = 1000114001,
+ VK_STRUCTURE_TYPE_FENCE_GET_WIN32_HANDLE_INFO_KHR = 1000114002,
+ VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR = 1000115000,
+ VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR = 1000115001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR = 1000119000,
+ VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR = 1000119001,
+ VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR = 1000119002,
+ VK_STRUCTURE_TYPE_IOS_SURFACE_CREATE_INFO_MVK = 1000122000,
+ VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK = 1000123000,
+ VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT = 1000128000,
+ VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT = 1000128001,
+ VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT = 1000128002,
+ VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT = 1000128003,
+ VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT = 1000128004,
+ VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_USAGE_ANDROID = 1000129000,
+ VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_PROPERTIES_ANDROID = 1000129001,
+ VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_FORMAT_PROPERTIES_ANDROID = 1000129002,
+ VK_STRUCTURE_TYPE_IMPORT_ANDROID_HARDWARE_BUFFER_INFO_ANDROID = 1000129003,
+ VK_STRUCTURE_TYPE_MEMORY_GET_ANDROID_HARDWARE_BUFFER_INFO_ANDROID = 1000129004,
+ VK_STRUCTURE_TYPE_EXTERNAL_FORMAT_ANDROID = 1000129005,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT = 1000130000,
+ VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT = 1000130001,
+ VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT = 1000143000,
+ VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT = 1000143001,
+ VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT = 1000143002,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT = 1000143003,
+ VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT = 1000143004,
+ VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR = 1000147000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT = 1000148000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT = 1000148001,
+ VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT = 1000148002,
+ VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV = 1000149000,
+ VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV = 1000152000,
+ VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT = 1000160000,
+ VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT = 1000160001,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_BINDING_FLAGS_CREATE_INFO_EXT = 1000161000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_FEATURES_EXT = 1000161001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_PROPERTIES_EXT = 1000161002,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_ALLOCATE_INFO_EXT = 1000161003,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_LAYOUT_SUPPORT_EXT = 1000161004,
+ VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT = 1000174000,
+ VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT = 1000178000,
+ VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT = 1000178001,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT = 1000178002,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_CORE_PROPERTIES_AMD = 1000185000,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT = 1000190000,
+ VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT = 1000190001,
+ VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2,
+ VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2,
+ VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2,
+ VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2,
+ VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2_KHR = VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2,
+ VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO_KHR = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO,
+ VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO_KHR = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO_KHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES,
+ VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO,
+ VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO,
+ VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES,
+ VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO,
+ VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_KHR = VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO,
+ VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES,
+ VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO,
+ VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES_KHR = VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES,
+ VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES,
+ VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO,
+ VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES,
+ VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS_KHR = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS,
+ VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO_KHR = VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO,
+ VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2_KHR = VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2,
+ VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2_KHR = VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2,
+ VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2_KHR = VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2,
+ VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2_KHR = VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2,
+ VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2_KHR = VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2,
+ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO_KHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO,
+ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO_KHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO_KHR = VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO,
+ VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO_KHR = VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES,
+ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES_KHR = VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES,
+ VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO_KHR = VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO,
+ VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO_KHR = VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO,
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES_KHR = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES,
+ VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT_KHR = VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT,
+ VK_STRUCTURE_TYPE_BEGIN_RANGE = VK_STRUCTURE_TYPE_APPLICATION_INFO,
+ VK_STRUCTURE_TYPE_END_RANGE = VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO,
+ VK_STRUCTURE_TYPE_RANGE_SIZE = (VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO - VK_STRUCTURE_TYPE_APPLICATION_INFO + 1),
+ VK_STRUCTURE_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkStructureType;
+
+typedef enum VkSystemAllocationScope {
+ VK_SYSTEM_ALLOCATION_SCOPE_COMMAND = 0,
+ VK_SYSTEM_ALLOCATION_SCOPE_OBJECT = 1,
+ VK_SYSTEM_ALLOCATION_SCOPE_CACHE = 2,
+ VK_SYSTEM_ALLOCATION_SCOPE_DEVICE = 3,
+ VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE = 4,
+ VK_SYSTEM_ALLOCATION_SCOPE_BEGIN_RANGE = VK_SYSTEM_ALLOCATION_SCOPE_COMMAND,
+ VK_SYSTEM_ALLOCATION_SCOPE_END_RANGE = VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE,
+ VK_SYSTEM_ALLOCATION_SCOPE_RANGE_SIZE = (VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE - VK_SYSTEM_ALLOCATION_SCOPE_COMMAND + 1),
+ VK_SYSTEM_ALLOCATION_SCOPE_MAX_ENUM = 0x7FFFFFFF
+} VkSystemAllocationScope;
+
+typedef enum VkInternalAllocationType {
+ VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE = 0,
+ VK_INTERNAL_ALLOCATION_TYPE_BEGIN_RANGE = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE,
+ VK_INTERNAL_ALLOCATION_TYPE_END_RANGE = VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE,
+ VK_INTERNAL_ALLOCATION_TYPE_RANGE_SIZE = (VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE - VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE + 1),
+ VK_INTERNAL_ALLOCATION_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkInternalAllocationType;
+
+typedef enum VkFormat {
+ VK_FORMAT_UNDEFINED = 0,
+ VK_FORMAT_R4G4_UNORM_PACK8 = 1,
+ VK_FORMAT_R4G4B4A4_UNORM_PACK16 = 2,
+ VK_FORMAT_B4G4R4A4_UNORM_PACK16 = 3,
+ VK_FORMAT_R5G6B5_UNORM_PACK16 = 4,
+ VK_FORMAT_B5G6R5_UNORM_PACK16 = 5,
+ VK_FORMAT_R5G5B5A1_UNORM_PACK16 = 6,
+ VK_FORMAT_B5G5R5A1_UNORM_PACK16 = 7,
+ VK_FORMAT_A1R5G5B5_UNORM_PACK16 = 8,
+ VK_FORMAT_R8_UNORM = 9,
+ VK_FORMAT_R8_SNORM = 10,
+ VK_FORMAT_R8_USCALED = 11,
+ VK_FORMAT_R8_SSCALED = 12,
+ VK_FORMAT_R8_UINT = 13,
+ VK_FORMAT_R8_SINT = 14,
+ VK_FORMAT_R8_SRGB = 15,
+ VK_FORMAT_R8G8_UNORM = 16,
+ VK_FORMAT_R8G8_SNORM = 17,
+ VK_FORMAT_R8G8_USCALED = 18,
+ VK_FORMAT_R8G8_SSCALED = 19,
+ VK_FORMAT_R8G8_UINT = 20,
+ VK_FORMAT_R8G8_SINT = 21,
+ VK_FORMAT_R8G8_SRGB = 22,
+ VK_FORMAT_R8G8B8_UNORM = 23,
+ VK_FORMAT_R8G8B8_SNORM = 24,
+ VK_FORMAT_R8G8B8_USCALED = 25,
+ VK_FORMAT_R8G8B8_SSCALED = 26,
+ VK_FORMAT_R8G8B8_UINT = 27,
+ VK_FORMAT_R8G8B8_SINT = 28,
+ VK_FORMAT_R8G8B8_SRGB = 29,
+ VK_FORMAT_B8G8R8_UNORM = 30,
+ VK_FORMAT_B8G8R8_SNORM = 31,
+ VK_FORMAT_B8G8R8_USCALED = 32,
+ VK_FORMAT_B8G8R8_SSCALED = 33,
+ VK_FORMAT_B8G8R8_UINT = 34,
+ VK_FORMAT_B8G8R8_SINT = 35,
+ VK_FORMAT_B8G8R8_SRGB = 36,
+ VK_FORMAT_R8G8B8A8_UNORM = 37,
+ VK_FORMAT_R8G8B8A8_SNORM = 38,
+ VK_FORMAT_R8G8B8A8_USCALED = 39,
+ VK_FORMAT_R8G8B8A8_SSCALED = 40,
+ VK_FORMAT_R8G8B8A8_UINT = 41,
+ VK_FORMAT_R8G8B8A8_SINT = 42,
+ VK_FORMAT_R8G8B8A8_SRGB = 43,
+ VK_FORMAT_B8G8R8A8_UNORM = 44,
+ VK_FORMAT_B8G8R8A8_SNORM = 45,
+ VK_FORMAT_B8G8R8A8_USCALED = 46,
+ VK_FORMAT_B8G8R8A8_SSCALED = 47,
+ VK_FORMAT_B8G8R8A8_UINT = 48,
+ VK_FORMAT_B8G8R8A8_SINT = 49,
+ VK_FORMAT_B8G8R8A8_SRGB = 50,
+ VK_FORMAT_A8B8G8R8_UNORM_PACK32 = 51,
+ VK_FORMAT_A8B8G8R8_SNORM_PACK32 = 52,
+ VK_FORMAT_A8B8G8R8_USCALED_PACK32 = 53,
+ VK_FORMAT_A8B8G8R8_SSCALED_PACK32 = 54,
+ VK_FORMAT_A8B8G8R8_UINT_PACK32 = 55,
+ VK_FORMAT_A8B8G8R8_SINT_PACK32 = 56,
+ VK_FORMAT_A8B8G8R8_SRGB_PACK32 = 57,
+ VK_FORMAT_A2R10G10B10_UNORM_PACK32 = 58,
+ VK_FORMAT_A2R10G10B10_SNORM_PACK32 = 59,
+ VK_FORMAT_A2R10G10B10_USCALED_PACK32 = 60,
+ VK_FORMAT_A2R10G10B10_SSCALED_PACK32 = 61,
+ VK_FORMAT_A2R10G10B10_UINT_PACK32 = 62,
+ VK_FORMAT_A2R10G10B10_SINT_PACK32 = 63,
+ VK_FORMAT_A2B10G10R10_UNORM_PACK32 = 64,
+ VK_FORMAT_A2B10G10R10_SNORM_PACK32 = 65,
+ VK_FORMAT_A2B10G10R10_USCALED_PACK32 = 66,
+ VK_FORMAT_A2B10G10R10_SSCALED_PACK32 = 67,
+ VK_FORMAT_A2B10G10R10_UINT_PACK32 = 68,
+ VK_FORMAT_A2B10G10R10_SINT_PACK32 = 69,
+ VK_FORMAT_R16_UNORM = 70,
+ VK_FORMAT_R16_SNORM = 71,
+ VK_FORMAT_R16_USCALED = 72,
+ VK_FORMAT_R16_SSCALED = 73,
+ VK_FORMAT_R16_UINT = 74,
+ VK_FORMAT_R16_SINT = 75,
+ VK_FORMAT_R16_SFLOAT = 76,
+ VK_FORMAT_R16G16_UNORM = 77,
+ VK_FORMAT_R16G16_SNORM = 78,
+ VK_FORMAT_R16G16_USCALED = 79,
+ VK_FORMAT_R16G16_SSCALED = 80,
+ VK_FORMAT_R16G16_UINT = 81,
+ VK_FORMAT_R16G16_SINT = 82,
+ VK_FORMAT_R16G16_SFLOAT = 83,
+ VK_FORMAT_R16G16B16_UNORM = 84,
+ VK_FORMAT_R16G16B16_SNORM = 85,
+ VK_FORMAT_R16G16B16_USCALED = 86,
+ VK_FORMAT_R16G16B16_SSCALED = 87,
+ VK_FORMAT_R16G16B16_UINT = 88,
+ VK_FORMAT_R16G16B16_SINT = 89,
+ VK_FORMAT_R16G16B16_SFLOAT = 90,
+ VK_FORMAT_R16G16B16A16_UNORM = 91,
+ VK_FORMAT_R16G16B16A16_SNORM = 92,
+ VK_FORMAT_R16G16B16A16_USCALED = 93,
+ VK_FORMAT_R16G16B16A16_SSCALED = 94,
+ VK_FORMAT_R16G16B16A16_UINT = 95,
+ VK_FORMAT_R16G16B16A16_SINT = 96,
+ VK_FORMAT_R16G16B16A16_SFLOAT = 97,
+ VK_FORMAT_R32_UINT = 98,
+ VK_FORMAT_R32_SINT = 99,
+ VK_FORMAT_R32_SFLOAT = 100,
+ VK_FORMAT_R32G32_UINT = 101,
+ VK_FORMAT_R32G32_SINT = 102,
+ VK_FORMAT_R32G32_SFLOAT = 103,
+ VK_FORMAT_R32G32B32_UINT = 104,
+ VK_FORMAT_R32G32B32_SINT = 105,
+ VK_FORMAT_R32G32B32_SFLOAT = 106,
+ VK_FORMAT_R32G32B32A32_UINT = 107,
+ VK_FORMAT_R32G32B32A32_SINT = 108,
+ VK_FORMAT_R32G32B32A32_SFLOAT = 109,
+ VK_FORMAT_R64_UINT = 110,
+ VK_FORMAT_R64_SINT = 111,
+ VK_FORMAT_R64_SFLOAT = 112,
+ VK_FORMAT_R64G64_UINT = 113,
+ VK_FORMAT_R64G64_SINT = 114,
+ VK_FORMAT_R64G64_SFLOAT = 115,
+ VK_FORMAT_R64G64B64_UINT = 116,
+ VK_FORMAT_R64G64B64_SINT = 117,
+ VK_FORMAT_R64G64B64_SFLOAT = 118,
+ VK_FORMAT_R64G64B64A64_UINT = 119,
+ VK_FORMAT_R64G64B64A64_SINT = 120,
+ VK_FORMAT_R64G64B64A64_SFLOAT = 121,
+ VK_FORMAT_B10G11R11_UFLOAT_PACK32 = 122,
+ VK_FORMAT_E5B9G9R9_UFLOAT_PACK32 = 123,
+ VK_FORMAT_D16_UNORM = 124,
+ VK_FORMAT_X8_D24_UNORM_PACK32 = 125,
+ VK_FORMAT_D32_SFLOAT = 126,
+ VK_FORMAT_S8_UINT = 127,
+ VK_FORMAT_D16_UNORM_S8_UINT = 128,
+ VK_FORMAT_D24_UNORM_S8_UINT = 129,
+ VK_FORMAT_D32_SFLOAT_S8_UINT = 130,
+ VK_FORMAT_BC1_RGB_UNORM_BLOCK = 131,
+ VK_FORMAT_BC1_RGB_SRGB_BLOCK = 132,
+ VK_FORMAT_BC1_RGBA_UNORM_BLOCK = 133,
+ VK_FORMAT_BC1_RGBA_SRGB_BLOCK = 134,
+ VK_FORMAT_BC2_UNORM_BLOCK = 135,
+ VK_FORMAT_BC2_SRGB_BLOCK = 136,
+ VK_FORMAT_BC3_UNORM_BLOCK = 137,
+ VK_FORMAT_BC3_SRGB_BLOCK = 138,
+ VK_FORMAT_BC4_UNORM_BLOCK = 139,
+ VK_FORMAT_BC4_SNORM_BLOCK = 140,
+ VK_FORMAT_BC5_UNORM_BLOCK = 141,
+ VK_FORMAT_BC5_SNORM_BLOCK = 142,
+ VK_FORMAT_BC6H_UFLOAT_BLOCK = 143,
+ VK_FORMAT_BC6H_SFLOAT_BLOCK = 144,
+ VK_FORMAT_BC7_UNORM_BLOCK = 145,
+ VK_FORMAT_BC7_SRGB_BLOCK = 146,
+ VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK = 147,
+ VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK = 148,
+ VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK = 149,
+ VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK = 150,
+ VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK = 151,
+ VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK = 152,
+ VK_FORMAT_EAC_R11_UNORM_BLOCK = 153,
+ VK_FORMAT_EAC_R11_SNORM_BLOCK = 154,
+ VK_FORMAT_EAC_R11G11_UNORM_BLOCK = 155,
+ VK_FORMAT_EAC_R11G11_SNORM_BLOCK = 156,
+ VK_FORMAT_ASTC_4x4_UNORM_BLOCK = 157,
+ VK_FORMAT_ASTC_4x4_SRGB_BLOCK = 158,
+ VK_FORMAT_ASTC_5x4_UNORM_BLOCK = 159,
+ VK_FORMAT_ASTC_5x4_SRGB_BLOCK = 160,
+ VK_FORMAT_ASTC_5x5_UNORM_BLOCK = 161,
+ VK_FORMAT_ASTC_5x5_SRGB_BLOCK = 162,
+ VK_FORMAT_ASTC_6x5_UNORM_BLOCK = 163,
+ VK_FORMAT_ASTC_6x5_SRGB_BLOCK = 164,
+ VK_FORMAT_ASTC_6x6_UNORM_BLOCK = 165,
+ VK_FORMAT_ASTC_6x6_SRGB_BLOCK = 166,
+ VK_FORMAT_ASTC_8x5_UNORM_BLOCK = 167,
+ VK_FORMAT_ASTC_8x5_SRGB_BLOCK = 168,
+ VK_FORMAT_ASTC_8x6_UNORM_BLOCK = 169,
+ VK_FORMAT_ASTC_8x6_SRGB_BLOCK = 170,
+ VK_FORMAT_ASTC_8x8_UNORM_BLOCK = 171,
+ VK_FORMAT_ASTC_8x8_SRGB_BLOCK = 172,
+ VK_FORMAT_ASTC_10x5_UNORM_BLOCK = 173,
+ VK_FORMAT_ASTC_10x5_SRGB_BLOCK = 174,
+ VK_FORMAT_ASTC_10x6_UNORM_BLOCK = 175,
+ VK_FORMAT_ASTC_10x6_SRGB_BLOCK = 176,
+ VK_FORMAT_ASTC_10x8_UNORM_BLOCK = 177,
+ VK_FORMAT_ASTC_10x8_SRGB_BLOCK = 178,
+ VK_FORMAT_ASTC_10x10_UNORM_BLOCK = 179,
+ VK_FORMAT_ASTC_10x10_SRGB_BLOCK = 180,
+ VK_FORMAT_ASTC_12x10_UNORM_BLOCK = 181,
+ VK_FORMAT_ASTC_12x10_SRGB_BLOCK = 182,
+ VK_FORMAT_ASTC_12x12_UNORM_BLOCK = 183,
+ VK_FORMAT_ASTC_12x12_SRGB_BLOCK = 184,
+ VK_FORMAT_G8B8G8R8_422_UNORM = 1000156000,
+ VK_FORMAT_B8G8R8G8_422_UNORM = 1000156001,
+ VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM = 1000156002,
+ VK_FORMAT_G8_B8R8_2PLANE_420_UNORM = 1000156003,
+ VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM = 1000156004,
+ VK_FORMAT_G8_B8R8_2PLANE_422_UNORM = 1000156005,
+ VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM = 1000156006,
+ VK_FORMAT_R10X6_UNORM_PACK16 = 1000156007,
+ VK_FORMAT_R10X6G10X6_UNORM_2PACK16 = 1000156008,
+ VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16 = 1000156009,
+ VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16 = 1000156010,
+ VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16 = 1000156011,
+ VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16 = 1000156012,
+ VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16 = 1000156013,
+ VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16 = 1000156014,
+ VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16 = 1000156015,
+ VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16 = 1000156016,
+ VK_FORMAT_R12X4_UNORM_PACK16 = 1000156017,
+ VK_FORMAT_R12X4G12X4_UNORM_2PACK16 = 1000156018,
+ VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16 = 1000156019,
+ VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16 = 1000156020,
+ VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16 = 1000156021,
+ VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16 = 1000156022,
+ VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16 = 1000156023,
+ VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16 = 1000156024,
+ VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16 = 1000156025,
+ VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16 = 1000156026,
+ VK_FORMAT_G16B16G16R16_422_UNORM = 1000156027,
+ VK_FORMAT_B16G16R16G16_422_UNORM = 1000156028,
+ VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM = 1000156029,
+ VK_FORMAT_G16_B16R16_2PLANE_420_UNORM = 1000156030,
+ VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM = 1000156031,
+ VK_FORMAT_G16_B16R16_2PLANE_422_UNORM = 1000156032,
+ VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM = 1000156033,
+ VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG = 1000054000,
+ VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG = 1000054001,
+ VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG = 1000054002,
+ VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG = 1000054003,
+ VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG = 1000054004,
+ VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG = 1000054005,
+ VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG = 1000054006,
+ VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG = 1000054007,
+ VK_FORMAT_G8B8G8R8_422_UNORM_KHR = VK_FORMAT_G8B8G8R8_422_UNORM,
+ VK_FORMAT_B8G8R8G8_422_UNORM_KHR = VK_FORMAT_B8G8R8G8_422_UNORM,
+ VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR = VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM,
+ VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR = VK_FORMAT_G8_B8R8_2PLANE_420_UNORM,
+ VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR = VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM,
+ VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR = VK_FORMAT_G8_B8R8_2PLANE_422_UNORM,
+ VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR = VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM,
+ VK_FORMAT_R10X6_UNORM_PACK16_KHR = VK_FORMAT_R10X6_UNORM_PACK16,
+ VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR = VK_FORMAT_R10X6G10X6_UNORM_2PACK16,
+ VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR = VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16,
+ VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR = VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16,
+ VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR = VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16,
+ VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16,
+ VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16,
+ VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16,
+ VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16,
+ VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR = VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16,
+ VK_FORMAT_R12X4_UNORM_PACK16_KHR = VK_FORMAT_R12X4_UNORM_PACK16,
+ VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR = VK_FORMAT_R12X4G12X4_UNORM_2PACK16,
+ VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR = VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16,
+ VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR = VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16,
+ VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR = VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16,
+ VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16,
+ VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16,
+ VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16,
+ VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16,
+ VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR = VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16,
+ VK_FORMAT_G16B16G16R16_422_UNORM_KHR = VK_FORMAT_G16B16G16R16_422_UNORM,
+ VK_FORMAT_B16G16R16G16_422_UNORM_KHR = VK_FORMAT_B16G16R16G16_422_UNORM,
+ VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR = VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM,
+ VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR = VK_FORMAT_G16_B16R16_2PLANE_420_UNORM,
+ VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR = VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM,
+ VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR = VK_FORMAT_G16_B16R16_2PLANE_422_UNORM,
+ VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR = VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM,
+ VK_FORMAT_BEGIN_RANGE = VK_FORMAT_UNDEFINED,
+ VK_FORMAT_END_RANGE = VK_FORMAT_ASTC_12x12_SRGB_BLOCK,
+ VK_FORMAT_RANGE_SIZE = (VK_FORMAT_ASTC_12x12_SRGB_BLOCK - VK_FORMAT_UNDEFINED + 1),
+ VK_FORMAT_MAX_ENUM = 0x7FFFFFFF
+} VkFormat;
+
+typedef enum VkImageType {
+ VK_IMAGE_TYPE_1D = 0,
+ VK_IMAGE_TYPE_2D = 1,
+ VK_IMAGE_TYPE_3D = 2,
+ VK_IMAGE_TYPE_BEGIN_RANGE = VK_IMAGE_TYPE_1D,
+ VK_IMAGE_TYPE_END_RANGE = VK_IMAGE_TYPE_3D,
+ VK_IMAGE_TYPE_RANGE_SIZE = (VK_IMAGE_TYPE_3D - VK_IMAGE_TYPE_1D + 1),
+ VK_IMAGE_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkImageType;
+
+typedef enum VkImageTiling {
+ VK_IMAGE_TILING_OPTIMAL = 0,
+ VK_IMAGE_TILING_LINEAR = 1,
+ VK_IMAGE_TILING_BEGIN_RANGE = VK_IMAGE_TILING_OPTIMAL,
+ VK_IMAGE_TILING_END_RANGE = VK_IMAGE_TILING_LINEAR,
+ VK_IMAGE_TILING_RANGE_SIZE = (VK_IMAGE_TILING_LINEAR - VK_IMAGE_TILING_OPTIMAL + 1),
+ VK_IMAGE_TILING_MAX_ENUM = 0x7FFFFFFF
+} VkImageTiling;
+
+typedef enum VkPhysicalDeviceType {
+ VK_PHYSICAL_DEVICE_TYPE_OTHER = 0,
+ VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU = 1,
+ VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU = 2,
+ VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU = 3,
+ VK_PHYSICAL_DEVICE_TYPE_CPU = 4,
+ VK_PHYSICAL_DEVICE_TYPE_BEGIN_RANGE = VK_PHYSICAL_DEVICE_TYPE_OTHER,
+ VK_PHYSICAL_DEVICE_TYPE_END_RANGE = VK_PHYSICAL_DEVICE_TYPE_CPU,
+ VK_PHYSICAL_DEVICE_TYPE_RANGE_SIZE = (VK_PHYSICAL_DEVICE_TYPE_CPU - VK_PHYSICAL_DEVICE_TYPE_OTHER + 1),
+ VK_PHYSICAL_DEVICE_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkPhysicalDeviceType;
+
+typedef enum VkQueryType {
+ VK_QUERY_TYPE_OCCLUSION = 0,
+ VK_QUERY_TYPE_PIPELINE_STATISTICS = 1,
+ VK_QUERY_TYPE_TIMESTAMP = 2,
+ VK_QUERY_TYPE_BEGIN_RANGE = VK_QUERY_TYPE_OCCLUSION,
+ VK_QUERY_TYPE_END_RANGE = VK_QUERY_TYPE_TIMESTAMP,
+ VK_QUERY_TYPE_RANGE_SIZE = (VK_QUERY_TYPE_TIMESTAMP - VK_QUERY_TYPE_OCCLUSION + 1),
+ VK_QUERY_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkQueryType;
+
+typedef enum VkSharingMode {
+ VK_SHARING_MODE_EXCLUSIVE = 0,
+ VK_SHARING_MODE_CONCURRENT = 1,
+ VK_SHARING_MODE_BEGIN_RANGE = VK_SHARING_MODE_EXCLUSIVE,
+ VK_SHARING_MODE_END_RANGE = VK_SHARING_MODE_CONCURRENT,
+ VK_SHARING_MODE_RANGE_SIZE = (VK_SHARING_MODE_CONCURRENT - VK_SHARING_MODE_EXCLUSIVE + 1),
+ VK_SHARING_MODE_MAX_ENUM = 0x7FFFFFFF
+} VkSharingMode;
+
+typedef enum VkImageLayout {
+ VK_IMAGE_LAYOUT_UNDEFINED = 0,
+ VK_IMAGE_LAYOUT_GENERAL = 1,
+ VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL = 2,
+ VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL = 3,
+ VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL = 4,
+ VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL = 5,
+ VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL = 6,
+ VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL = 7,
+ VK_IMAGE_LAYOUT_PREINITIALIZED = 8,
+ VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL = 1000117000,
+ VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL = 1000117001,
+ VK_IMAGE_LAYOUT_PRESENT_SRC_KHR = 1000001002,
+ VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR = 1000111000,
+ VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL_KHR = VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL,
+ VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL_KHR = VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL,
+ VK_IMAGE_LAYOUT_BEGIN_RANGE = VK_IMAGE_LAYOUT_UNDEFINED,
+ VK_IMAGE_LAYOUT_END_RANGE = VK_IMAGE_LAYOUT_PREINITIALIZED,
+ VK_IMAGE_LAYOUT_RANGE_SIZE = (VK_IMAGE_LAYOUT_PREINITIALIZED - VK_IMAGE_LAYOUT_UNDEFINED + 1),
+ VK_IMAGE_LAYOUT_MAX_ENUM = 0x7FFFFFFF
+} VkImageLayout;
+
+typedef enum VkImageViewType {
+ VK_IMAGE_VIEW_TYPE_1D = 0,
+ VK_IMAGE_VIEW_TYPE_2D = 1,
+ VK_IMAGE_VIEW_TYPE_3D = 2,
+ VK_IMAGE_VIEW_TYPE_CUBE = 3,
+ VK_IMAGE_VIEW_TYPE_1D_ARRAY = 4,
+ VK_IMAGE_VIEW_TYPE_2D_ARRAY = 5,
+ VK_IMAGE_VIEW_TYPE_CUBE_ARRAY = 6,
+ VK_IMAGE_VIEW_TYPE_BEGIN_RANGE = VK_IMAGE_VIEW_TYPE_1D,
+ VK_IMAGE_VIEW_TYPE_END_RANGE = VK_IMAGE_VIEW_TYPE_CUBE_ARRAY,
+ VK_IMAGE_VIEW_TYPE_RANGE_SIZE = (VK_IMAGE_VIEW_TYPE_CUBE_ARRAY - VK_IMAGE_VIEW_TYPE_1D + 1),
+ VK_IMAGE_VIEW_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkImageViewType;
+
+typedef enum VkComponentSwizzle {
+ VK_COMPONENT_SWIZZLE_IDENTITY = 0,
+ VK_COMPONENT_SWIZZLE_ZERO = 1,
+ VK_COMPONENT_SWIZZLE_ONE = 2,
+ VK_COMPONENT_SWIZZLE_R = 3,
+ VK_COMPONENT_SWIZZLE_G = 4,
+ VK_COMPONENT_SWIZZLE_B = 5,
+ VK_COMPONENT_SWIZZLE_A = 6,
+ VK_COMPONENT_SWIZZLE_BEGIN_RANGE = VK_COMPONENT_SWIZZLE_IDENTITY,
+ VK_COMPONENT_SWIZZLE_END_RANGE = VK_COMPONENT_SWIZZLE_A,
+ VK_COMPONENT_SWIZZLE_RANGE_SIZE = (VK_COMPONENT_SWIZZLE_A - VK_COMPONENT_SWIZZLE_IDENTITY + 1),
+ VK_COMPONENT_SWIZZLE_MAX_ENUM = 0x7FFFFFFF
+} VkComponentSwizzle;
+
+typedef enum VkVertexInputRate {
+ VK_VERTEX_INPUT_RATE_VERTEX = 0,
+ VK_VERTEX_INPUT_RATE_INSTANCE = 1,
+ VK_VERTEX_INPUT_RATE_BEGIN_RANGE = VK_VERTEX_INPUT_RATE_VERTEX,
+ VK_VERTEX_INPUT_RATE_END_RANGE = VK_VERTEX_INPUT_RATE_INSTANCE,
+ VK_VERTEX_INPUT_RATE_RANGE_SIZE = (VK_VERTEX_INPUT_RATE_INSTANCE - VK_VERTEX_INPUT_RATE_VERTEX + 1),
+ VK_VERTEX_INPUT_RATE_MAX_ENUM = 0x7FFFFFFF
+} VkVertexInputRate;
+
+typedef enum VkPrimitiveTopology {
+ VK_PRIMITIVE_TOPOLOGY_POINT_LIST = 0,
+ VK_PRIMITIVE_TOPOLOGY_LINE_LIST = 1,
+ VK_PRIMITIVE_TOPOLOGY_LINE_STRIP = 2,
+ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST = 3,
+ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP = 4,
+ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_FAN = 5,
+ VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY = 6,
+ VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY = 7,
+ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY = 8,
+ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY = 9,
+ VK_PRIMITIVE_TOPOLOGY_PATCH_LIST = 10,
+ VK_PRIMITIVE_TOPOLOGY_BEGIN_RANGE = VK_PRIMITIVE_TOPOLOGY_POINT_LIST,
+ VK_PRIMITIVE_TOPOLOGY_END_RANGE = VK_PRIMITIVE_TOPOLOGY_PATCH_LIST,
+ VK_PRIMITIVE_TOPOLOGY_RANGE_SIZE = (VK_PRIMITIVE_TOPOLOGY_PATCH_LIST - VK_PRIMITIVE_TOPOLOGY_POINT_LIST + 1),
+ VK_PRIMITIVE_TOPOLOGY_MAX_ENUM = 0x7FFFFFFF
+} VkPrimitiveTopology;
+
+typedef enum VkPolygonMode {
+ VK_POLYGON_MODE_FILL = 0,
+ VK_POLYGON_MODE_LINE = 1,
+ VK_POLYGON_MODE_POINT = 2,
+ VK_POLYGON_MODE_FILL_RECTANGLE_NV = 1000153000,
+ VK_POLYGON_MODE_BEGIN_RANGE = VK_POLYGON_MODE_FILL,
+ VK_POLYGON_MODE_END_RANGE = VK_POLYGON_MODE_POINT,
+ VK_POLYGON_MODE_RANGE_SIZE = (VK_POLYGON_MODE_POINT - VK_POLYGON_MODE_FILL + 1),
+ VK_POLYGON_MODE_MAX_ENUM = 0x7FFFFFFF
+} VkPolygonMode;
+
+typedef enum VkFrontFace {
+ VK_FRONT_FACE_COUNTER_CLOCKWISE = 0,
+ VK_FRONT_FACE_CLOCKWISE = 1,
+ VK_FRONT_FACE_BEGIN_RANGE = VK_FRONT_FACE_COUNTER_CLOCKWISE,
+ VK_FRONT_FACE_END_RANGE = VK_FRONT_FACE_CLOCKWISE,
+ VK_FRONT_FACE_RANGE_SIZE = (VK_FRONT_FACE_CLOCKWISE - VK_FRONT_FACE_COUNTER_CLOCKWISE + 1),
+ VK_FRONT_FACE_MAX_ENUM = 0x7FFFFFFF
+} VkFrontFace;
+
+typedef enum VkCompareOp {
+ VK_COMPARE_OP_NEVER = 0,
+ VK_COMPARE_OP_LESS = 1,
+ VK_COMPARE_OP_EQUAL = 2,
+ VK_COMPARE_OP_LESS_OR_EQUAL = 3,
+ VK_COMPARE_OP_GREATER = 4,
+ VK_COMPARE_OP_NOT_EQUAL = 5,
+ VK_COMPARE_OP_GREATER_OR_EQUAL = 6,
+ VK_COMPARE_OP_ALWAYS = 7,
+ VK_COMPARE_OP_BEGIN_RANGE = VK_COMPARE_OP_NEVER,
+ VK_COMPARE_OP_END_RANGE = VK_COMPARE_OP_ALWAYS,
+ VK_COMPARE_OP_RANGE_SIZE = (VK_COMPARE_OP_ALWAYS - VK_COMPARE_OP_NEVER + 1),
+ VK_COMPARE_OP_MAX_ENUM = 0x7FFFFFFF
+} VkCompareOp;
+
+typedef enum VkStencilOp {
+ VK_STENCIL_OP_KEEP = 0,
+ VK_STENCIL_OP_ZERO = 1,
+ VK_STENCIL_OP_REPLACE = 2,
+ VK_STENCIL_OP_INCREMENT_AND_CLAMP = 3,
+ VK_STENCIL_OP_DECREMENT_AND_CLAMP = 4,
+ VK_STENCIL_OP_INVERT = 5,
+ VK_STENCIL_OP_INCREMENT_AND_WRAP = 6,
+ VK_STENCIL_OP_DECREMENT_AND_WRAP = 7,
+ VK_STENCIL_OP_BEGIN_RANGE = VK_STENCIL_OP_KEEP,
+ VK_STENCIL_OP_END_RANGE = VK_STENCIL_OP_DECREMENT_AND_WRAP,
+ VK_STENCIL_OP_RANGE_SIZE = (VK_STENCIL_OP_DECREMENT_AND_WRAP - VK_STENCIL_OP_KEEP + 1),
+ VK_STENCIL_OP_MAX_ENUM = 0x7FFFFFFF
+} VkStencilOp;
+
+typedef enum VkLogicOp {
+ VK_LOGIC_OP_CLEAR = 0,
+ VK_LOGIC_OP_AND = 1,
+ VK_LOGIC_OP_AND_REVERSE = 2,
+ VK_LOGIC_OP_COPY = 3,
+ VK_LOGIC_OP_AND_INVERTED = 4,
+ VK_LOGIC_OP_NO_OP = 5,
+ VK_LOGIC_OP_XOR = 6,
+ VK_LOGIC_OP_OR = 7,
+ VK_LOGIC_OP_NOR = 8,
+ VK_LOGIC_OP_EQUIVALENT = 9,
+ VK_LOGIC_OP_INVERT = 10,
+ VK_LOGIC_OP_OR_REVERSE = 11,
+ VK_LOGIC_OP_COPY_INVERTED = 12,
+ VK_LOGIC_OP_OR_INVERTED = 13,
+ VK_LOGIC_OP_NAND = 14,
+ VK_LOGIC_OP_SET = 15,
+ VK_LOGIC_OP_BEGIN_RANGE = VK_LOGIC_OP_CLEAR,
+ VK_LOGIC_OP_END_RANGE = VK_LOGIC_OP_SET,
+ VK_LOGIC_OP_RANGE_SIZE = (VK_LOGIC_OP_SET - VK_LOGIC_OP_CLEAR + 1),
+ VK_LOGIC_OP_MAX_ENUM = 0x7FFFFFFF
+} VkLogicOp;
+
+typedef enum VkBlendFactor {
+ VK_BLEND_FACTOR_ZERO = 0,
+ VK_BLEND_FACTOR_ONE = 1,
+ VK_BLEND_FACTOR_SRC_COLOR = 2,
+ VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR = 3,
+ VK_BLEND_FACTOR_DST_COLOR = 4,
+ VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR = 5,
+ VK_BLEND_FACTOR_SRC_ALPHA = 6,
+ VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA = 7,
+ VK_BLEND_FACTOR_DST_ALPHA = 8,
+ VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA = 9,
+ VK_BLEND_FACTOR_CONSTANT_COLOR = 10,
+ VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COLOR = 11,
+ VK_BLEND_FACTOR_CONSTANT_ALPHA = 12,
+ VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_ALPHA = 13,
+ VK_BLEND_FACTOR_SRC_ALPHA_SATURATE = 14,
+ VK_BLEND_FACTOR_SRC1_COLOR = 15,
+ VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR = 16,
+ VK_BLEND_FACTOR_SRC1_ALPHA = 17,
+ VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA = 18,
+ VK_BLEND_FACTOR_BEGIN_RANGE = VK_BLEND_FACTOR_ZERO,
+ VK_BLEND_FACTOR_END_RANGE = VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA,
+ VK_BLEND_FACTOR_RANGE_SIZE = (VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA - VK_BLEND_FACTOR_ZERO + 1),
+ VK_BLEND_FACTOR_MAX_ENUM = 0x7FFFFFFF
+} VkBlendFactor;
+
+typedef enum VkBlendOp {
+ VK_BLEND_OP_ADD = 0,
+ VK_BLEND_OP_SUBTRACT = 1,
+ VK_BLEND_OP_REVERSE_SUBTRACT = 2,
+ VK_BLEND_OP_MIN = 3,
+ VK_BLEND_OP_MAX = 4,
+ VK_BLEND_OP_ZERO_EXT = 1000148000,
+ VK_BLEND_OP_SRC_EXT = 1000148001,
+ VK_BLEND_OP_DST_EXT = 1000148002,
+ VK_BLEND_OP_SRC_OVER_EXT = 1000148003,
+ VK_BLEND_OP_DST_OVER_EXT = 1000148004,
+ VK_BLEND_OP_SRC_IN_EXT = 1000148005,
+ VK_BLEND_OP_DST_IN_EXT = 1000148006,
+ VK_BLEND_OP_SRC_OUT_EXT = 1000148007,
+ VK_BLEND_OP_DST_OUT_EXT = 1000148008,
+ VK_BLEND_OP_SRC_ATOP_EXT = 1000148009,
+ VK_BLEND_OP_DST_ATOP_EXT = 1000148010,
+ VK_BLEND_OP_XOR_EXT = 1000148011,
+ VK_BLEND_OP_MULTIPLY_EXT = 1000148012,
+ VK_BLEND_OP_SCREEN_EXT = 1000148013,
+ VK_BLEND_OP_OVERLAY_EXT = 1000148014,
+ VK_BLEND_OP_DARKEN_EXT = 1000148015,
+ VK_BLEND_OP_LIGHTEN_EXT = 1000148016,
+ VK_BLEND_OP_COLORDODGE_EXT = 1000148017,
+ VK_BLEND_OP_COLORBURN_EXT = 1000148018,
+ VK_BLEND_OP_HARDLIGHT_EXT = 1000148019,
+ VK_BLEND_OP_SOFTLIGHT_EXT = 1000148020,
+ VK_BLEND_OP_DIFFERENCE_EXT = 1000148021,
+ VK_BLEND_OP_EXCLUSION_EXT = 1000148022,
+ VK_BLEND_OP_INVERT_EXT = 1000148023,
+ VK_BLEND_OP_INVERT_RGB_EXT = 1000148024,
+ VK_BLEND_OP_LINEARDODGE_EXT = 1000148025,
+ VK_BLEND_OP_LINEARBURN_EXT = 1000148026,
+ VK_BLEND_OP_VIVIDLIGHT_EXT = 1000148027,
+ VK_BLEND_OP_LINEARLIGHT_EXT = 1000148028,
+ VK_BLEND_OP_PINLIGHT_EXT = 1000148029,
+ VK_BLEND_OP_HARDMIX_EXT = 1000148030,
+ VK_BLEND_OP_HSL_HUE_EXT = 1000148031,
+ VK_BLEND_OP_HSL_SATURATION_EXT = 1000148032,
+ VK_BLEND_OP_HSL_COLOR_EXT = 1000148033,
+ VK_BLEND_OP_HSL_LUMINOSITY_EXT = 1000148034,
+ VK_BLEND_OP_PLUS_EXT = 1000148035,
+ VK_BLEND_OP_PLUS_CLAMPED_EXT = 1000148036,
+ VK_BLEND_OP_PLUS_CLAMPED_ALPHA_EXT = 1000148037,
+ VK_BLEND_OP_PLUS_DARKER_EXT = 1000148038,
+ VK_BLEND_OP_MINUS_EXT = 1000148039,
+ VK_BLEND_OP_MINUS_CLAMPED_EXT = 1000148040,
+ VK_BLEND_OP_CONTRAST_EXT = 1000148041,
+ VK_BLEND_OP_INVERT_OVG_EXT = 1000148042,
+ VK_BLEND_OP_RED_EXT = 1000148043,
+ VK_BLEND_OP_GREEN_EXT = 1000148044,
+ VK_BLEND_OP_BLUE_EXT = 1000148045,
+ VK_BLEND_OP_BEGIN_RANGE = VK_BLEND_OP_ADD,
+ VK_BLEND_OP_END_RANGE = VK_BLEND_OP_MAX,
+ VK_BLEND_OP_RANGE_SIZE = (VK_BLEND_OP_MAX - VK_BLEND_OP_ADD + 1),
+ VK_BLEND_OP_MAX_ENUM = 0x7FFFFFFF
+} VkBlendOp;
+
+typedef enum VkDynamicState {
+ VK_DYNAMIC_STATE_VIEWPORT = 0,
+ VK_DYNAMIC_STATE_SCISSOR = 1,
+ VK_DYNAMIC_STATE_LINE_WIDTH = 2,
+ VK_DYNAMIC_STATE_DEPTH_BIAS = 3,
+ VK_DYNAMIC_STATE_BLEND_CONSTANTS = 4,
+ VK_DYNAMIC_STATE_DEPTH_BOUNDS = 5,
+ VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK = 6,
+ VK_DYNAMIC_STATE_STENCIL_WRITE_MASK = 7,
+ VK_DYNAMIC_STATE_STENCIL_REFERENCE = 8,
+ VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV = 1000087000,
+ VK_DYNAMIC_STATE_DISCARD_RECTANGLE_EXT = 1000099000,
+ VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT = 1000143000,
+ VK_DYNAMIC_STATE_BEGIN_RANGE = VK_DYNAMIC_STATE_VIEWPORT,
+ VK_DYNAMIC_STATE_END_RANGE = VK_DYNAMIC_STATE_STENCIL_REFERENCE,
+ VK_DYNAMIC_STATE_RANGE_SIZE = (VK_DYNAMIC_STATE_STENCIL_REFERENCE - VK_DYNAMIC_STATE_VIEWPORT + 1),
+ VK_DYNAMIC_STATE_MAX_ENUM = 0x7FFFFFFF
+} VkDynamicState;
+
+typedef enum VkFilter {
+ VK_FILTER_NEAREST = 0,
+ VK_FILTER_LINEAR = 1,
+ VK_FILTER_CUBIC_IMG = 1000015000,
+ VK_FILTER_BEGIN_RANGE = VK_FILTER_NEAREST,
+ VK_FILTER_END_RANGE = VK_FILTER_LINEAR,
+ VK_FILTER_RANGE_SIZE = (VK_FILTER_LINEAR - VK_FILTER_NEAREST + 1),
+ VK_FILTER_MAX_ENUM = 0x7FFFFFFF
+} VkFilter;
+
+typedef enum VkSamplerMipmapMode {
+ VK_SAMPLER_MIPMAP_MODE_NEAREST = 0,
+ VK_SAMPLER_MIPMAP_MODE_LINEAR = 1,
+ VK_SAMPLER_MIPMAP_MODE_BEGIN_RANGE = VK_SAMPLER_MIPMAP_MODE_NEAREST,
+ VK_SAMPLER_MIPMAP_MODE_END_RANGE = VK_SAMPLER_MIPMAP_MODE_LINEAR,
+ VK_SAMPLER_MIPMAP_MODE_RANGE_SIZE = (VK_SAMPLER_MIPMAP_MODE_LINEAR - VK_SAMPLER_MIPMAP_MODE_NEAREST + 1),
+ VK_SAMPLER_MIPMAP_MODE_MAX_ENUM = 0x7FFFFFFF
+} VkSamplerMipmapMode;
+
+typedef enum VkSamplerAddressMode {
+ VK_SAMPLER_ADDRESS_MODE_REPEAT = 0,
+ VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT = 1,
+ VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE = 2,
+ VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER = 3,
+ VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE = 4,
+ VK_SAMPLER_ADDRESS_MODE_BEGIN_RANGE = VK_SAMPLER_ADDRESS_MODE_REPEAT,
+ VK_SAMPLER_ADDRESS_MODE_END_RANGE = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER,
+ VK_SAMPLER_ADDRESS_MODE_RANGE_SIZE = (VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER - VK_SAMPLER_ADDRESS_MODE_REPEAT + 1),
+ VK_SAMPLER_ADDRESS_MODE_MAX_ENUM = 0x7FFFFFFF
+} VkSamplerAddressMode;
+
+typedef enum VkBorderColor {
+ VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK = 0,
+ VK_BORDER_COLOR_INT_TRANSPARENT_BLACK = 1,
+ VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK = 2,
+ VK_BORDER_COLOR_INT_OPAQUE_BLACK = 3,
+ VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE = 4,
+ VK_BORDER_COLOR_INT_OPAQUE_WHITE = 5,
+ VK_BORDER_COLOR_BEGIN_RANGE = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK,
+ VK_BORDER_COLOR_END_RANGE = VK_BORDER_COLOR_INT_OPAQUE_WHITE,
+ VK_BORDER_COLOR_RANGE_SIZE = (VK_BORDER_COLOR_INT_OPAQUE_WHITE - VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK + 1),
+ VK_BORDER_COLOR_MAX_ENUM = 0x7FFFFFFF
+} VkBorderColor;
+
+typedef enum VkDescriptorType {
+ VK_DESCRIPTOR_TYPE_SAMPLER = 0,
+ VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER = 1,
+ VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE = 2,
+ VK_DESCRIPTOR_TYPE_STORAGE_IMAGE = 3,
+ VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER = 4,
+ VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER = 5,
+ VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER = 6,
+ VK_DESCRIPTOR_TYPE_STORAGE_BUFFER = 7,
+ VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC = 8,
+ VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC = 9,
+ VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT = 10,
+ VK_DESCRIPTOR_TYPE_BEGIN_RANGE = VK_DESCRIPTOR_TYPE_SAMPLER,
+ VK_DESCRIPTOR_TYPE_END_RANGE = VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT,
+ VK_DESCRIPTOR_TYPE_RANGE_SIZE = (VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT - VK_DESCRIPTOR_TYPE_SAMPLER + 1),
+ VK_DESCRIPTOR_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkDescriptorType;
+
+typedef enum VkAttachmentLoadOp {
+ VK_ATTACHMENT_LOAD_OP_LOAD = 0,
+ VK_ATTACHMENT_LOAD_OP_CLEAR = 1,
+ VK_ATTACHMENT_LOAD_OP_DONT_CARE = 2,
+ VK_ATTACHMENT_LOAD_OP_BEGIN_RANGE = VK_ATTACHMENT_LOAD_OP_LOAD,
+ VK_ATTACHMENT_LOAD_OP_END_RANGE = VK_ATTACHMENT_LOAD_OP_DONT_CARE,
+ VK_ATTACHMENT_LOAD_OP_RANGE_SIZE = (VK_ATTACHMENT_LOAD_OP_DONT_CARE - VK_ATTACHMENT_LOAD_OP_LOAD + 1),
+ VK_ATTACHMENT_LOAD_OP_MAX_ENUM = 0x7FFFFFFF
+} VkAttachmentLoadOp;
+
+typedef enum VkAttachmentStoreOp {
+ VK_ATTACHMENT_STORE_OP_STORE = 0,
+ VK_ATTACHMENT_STORE_OP_DONT_CARE = 1,
+ VK_ATTACHMENT_STORE_OP_BEGIN_RANGE = VK_ATTACHMENT_STORE_OP_STORE,
+ VK_ATTACHMENT_STORE_OP_END_RANGE = VK_ATTACHMENT_STORE_OP_DONT_CARE,
+ VK_ATTACHMENT_STORE_OP_RANGE_SIZE = (VK_ATTACHMENT_STORE_OP_DONT_CARE - VK_ATTACHMENT_STORE_OP_STORE + 1),
+ VK_ATTACHMENT_STORE_OP_MAX_ENUM = 0x7FFFFFFF
+} VkAttachmentStoreOp;
+
+typedef enum VkPipelineBindPoint {
+ VK_PIPELINE_BIND_POINT_GRAPHICS = 0,
+ VK_PIPELINE_BIND_POINT_COMPUTE = 1,
+ VK_PIPELINE_BIND_POINT_BEGIN_RANGE = VK_PIPELINE_BIND_POINT_GRAPHICS,
+ VK_PIPELINE_BIND_POINT_END_RANGE = VK_PIPELINE_BIND_POINT_COMPUTE,
+ VK_PIPELINE_BIND_POINT_RANGE_SIZE = (VK_PIPELINE_BIND_POINT_COMPUTE - VK_PIPELINE_BIND_POINT_GRAPHICS + 1),
+ VK_PIPELINE_BIND_POINT_MAX_ENUM = 0x7FFFFFFF
+} VkPipelineBindPoint;
+
+typedef enum VkCommandBufferLevel {
+ VK_COMMAND_BUFFER_LEVEL_PRIMARY = 0,
+ VK_COMMAND_BUFFER_LEVEL_SECONDARY = 1,
+ VK_COMMAND_BUFFER_LEVEL_BEGIN_RANGE = VK_COMMAND_BUFFER_LEVEL_PRIMARY,
+ VK_COMMAND_BUFFER_LEVEL_END_RANGE = VK_COMMAND_BUFFER_LEVEL_SECONDARY,
+ VK_COMMAND_BUFFER_LEVEL_RANGE_SIZE = (VK_COMMAND_BUFFER_LEVEL_SECONDARY - VK_COMMAND_BUFFER_LEVEL_PRIMARY + 1),
+ VK_COMMAND_BUFFER_LEVEL_MAX_ENUM = 0x7FFFFFFF
+} VkCommandBufferLevel;
+
+typedef enum VkIndexType {
+ VK_INDEX_TYPE_UINT16 = 0,
+ VK_INDEX_TYPE_UINT32 = 1,
+ VK_INDEX_TYPE_BEGIN_RANGE = VK_INDEX_TYPE_UINT16,
+ VK_INDEX_TYPE_END_RANGE = VK_INDEX_TYPE_UINT32,
+ VK_INDEX_TYPE_RANGE_SIZE = (VK_INDEX_TYPE_UINT32 - VK_INDEX_TYPE_UINT16 + 1),
+ VK_INDEX_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkIndexType;
+
+typedef enum VkSubpassContents {
+ VK_SUBPASS_CONTENTS_INLINE = 0,
+ VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS = 1,
+ VK_SUBPASS_CONTENTS_BEGIN_RANGE = VK_SUBPASS_CONTENTS_INLINE,
+ VK_SUBPASS_CONTENTS_END_RANGE = VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS,
+ VK_SUBPASS_CONTENTS_RANGE_SIZE = (VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS - VK_SUBPASS_CONTENTS_INLINE + 1),
+ VK_SUBPASS_CONTENTS_MAX_ENUM = 0x7FFFFFFF
+} VkSubpassContents;
+
+typedef enum VkObjectType {
+ VK_OBJECT_TYPE_UNKNOWN = 0,
+ VK_OBJECT_TYPE_INSTANCE = 1,
+ VK_OBJECT_TYPE_PHYSICAL_DEVICE = 2,
+ VK_OBJECT_TYPE_DEVICE = 3,
+ VK_OBJECT_TYPE_QUEUE = 4,
+ VK_OBJECT_TYPE_SEMAPHORE = 5,
+ VK_OBJECT_TYPE_COMMAND_BUFFER = 6,
+ VK_OBJECT_TYPE_FENCE = 7,
+ VK_OBJECT_TYPE_DEVICE_MEMORY = 8,
+ VK_OBJECT_TYPE_BUFFER = 9,
+ VK_OBJECT_TYPE_IMAGE = 10,
+ VK_OBJECT_TYPE_EVENT = 11,
+ VK_OBJECT_TYPE_QUERY_POOL = 12,
+ VK_OBJECT_TYPE_BUFFER_VIEW = 13,
+ VK_OBJECT_TYPE_IMAGE_VIEW = 14,
+ VK_OBJECT_TYPE_SHADER_MODULE = 15,
+ VK_OBJECT_TYPE_PIPELINE_CACHE = 16,
+ VK_OBJECT_TYPE_PIPELINE_LAYOUT = 17,
+ VK_OBJECT_TYPE_RENDER_PASS = 18,
+ VK_OBJECT_TYPE_PIPELINE = 19,
+ VK_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT = 20,
+ VK_OBJECT_TYPE_SAMPLER = 21,
+ VK_OBJECT_TYPE_DESCRIPTOR_POOL = 22,
+ VK_OBJECT_TYPE_DESCRIPTOR_SET = 23,
+ VK_OBJECT_TYPE_FRAMEBUFFER = 24,
+ VK_OBJECT_TYPE_COMMAND_POOL = 25,
+ VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION = 1000156000,
+ VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE = 1000085000,
+ VK_OBJECT_TYPE_SURFACE_KHR = 1000000000,
+ VK_OBJECT_TYPE_SWAPCHAIN_KHR = 1000001000,
+ VK_OBJECT_TYPE_DISPLAY_KHR = 1000002000,
+ VK_OBJECT_TYPE_DISPLAY_MODE_KHR = 1000002001,
+ VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT = 1000011000,
+ VK_OBJECT_TYPE_OBJECT_TABLE_NVX = 1000086000,
+ VK_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX = 1000086001,
+ VK_OBJECT_TYPE_DEBUG_UTILS_MESSENGER_EXT = 1000128000,
+ VK_OBJECT_TYPE_VALIDATION_CACHE_EXT = 1000160000,
+ VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_KHR = VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE,
+ VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_KHR = VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION,
+ VK_OBJECT_TYPE_BEGIN_RANGE = VK_OBJECT_TYPE_UNKNOWN,
+ VK_OBJECT_TYPE_END_RANGE = VK_OBJECT_TYPE_COMMAND_POOL,
+ VK_OBJECT_TYPE_RANGE_SIZE = (VK_OBJECT_TYPE_COMMAND_POOL - VK_OBJECT_TYPE_UNKNOWN + 1),
+ VK_OBJECT_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkObjectType;
+
+typedef VkFlags VkInstanceCreateFlags;
+
+typedef enum VkFormatFeatureFlagBits {
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT = 0x00000001,
+ VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT = 0x00000002,
+ VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT = 0x00000004,
+ VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT = 0x00000008,
+ VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT = 0x00000010,
+ VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT = 0x00000020,
+ VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT = 0x00000040,
+ VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT = 0x00000080,
+ VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT = 0x00000100,
+ VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT = 0x00000200,
+ VK_FORMAT_FEATURE_BLIT_SRC_BIT = 0x00000400,
+ VK_FORMAT_FEATURE_BLIT_DST_BIT = 0x00000800,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT = 0x00001000,
+ VK_FORMAT_FEATURE_TRANSFER_SRC_BIT = 0x00004000,
+ VK_FORMAT_FEATURE_TRANSFER_DST_BIT = 0x00008000,
+ VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT = 0x00020000,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT = 0x00040000,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT = 0x00080000,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT = 0x00100000,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT = 0x00200000,
+ VK_FORMAT_FEATURE_DISJOINT_BIT = 0x00400000,
+ VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT = 0x00800000,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG = 0x00002000,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_MINMAX_BIT_EXT = 0x00010000,
+ VK_FORMAT_FEATURE_TRANSFER_SRC_BIT_KHR = VK_FORMAT_FEATURE_TRANSFER_SRC_BIT,
+ VK_FORMAT_FEATURE_TRANSFER_DST_BIT_KHR = VK_FORMAT_FEATURE_TRANSFER_DST_BIT,
+ VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT_KHR = VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT,
+ VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT_KHR = VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT,
+ VK_FORMAT_FEATURE_DISJOINT_BIT_KHR = VK_FORMAT_FEATURE_DISJOINT_BIT,
+ VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT_KHR = VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT,
+ VK_FORMAT_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkFormatFeatureFlagBits;
+typedef VkFlags VkFormatFeatureFlags;
+
+typedef enum VkImageUsageFlagBits {
+ VK_IMAGE_USAGE_TRANSFER_SRC_BIT = 0x00000001,
+ VK_IMAGE_USAGE_TRANSFER_DST_BIT = 0x00000002,
+ VK_IMAGE_USAGE_SAMPLED_BIT = 0x00000004,
+ VK_IMAGE_USAGE_STORAGE_BIT = 0x00000008,
+ VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT = 0x00000010,
+ VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT = 0x00000020,
+ VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT = 0x00000040,
+ VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT = 0x00000080,
+ VK_IMAGE_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkImageUsageFlagBits;
+typedef VkFlags VkImageUsageFlags;
+
+typedef enum VkImageCreateFlagBits {
+ VK_IMAGE_CREATE_SPARSE_BINDING_BIT = 0x00000001,
+ VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT = 0x00000002,
+ VK_IMAGE_CREATE_SPARSE_ALIASED_BIT = 0x00000004,
+ VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT = 0x00000008,
+ VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT = 0x00000010,
+ VK_IMAGE_CREATE_ALIAS_BIT = 0x00000400,
+ VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT = 0x00000040,
+ VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT = 0x00000020,
+ VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT = 0x00000080,
+ VK_IMAGE_CREATE_EXTENDED_USAGE_BIT = 0x00000100,
+ VK_IMAGE_CREATE_PROTECTED_BIT = 0x00000800,
+ VK_IMAGE_CREATE_DISJOINT_BIT = 0x00000200,
+ VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT = 0x00001000,
+ VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR = VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT,
+ VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT_KHR = VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT,
+ VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT_KHR = VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT,
+ VK_IMAGE_CREATE_EXTENDED_USAGE_BIT_KHR = VK_IMAGE_CREATE_EXTENDED_USAGE_BIT,
+ VK_IMAGE_CREATE_DISJOINT_BIT_KHR = VK_IMAGE_CREATE_DISJOINT_BIT,
+ VK_IMAGE_CREATE_ALIAS_BIT_KHR = VK_IMAGE_CREATE_ALIAS_BIT,
+ VK_IMAGE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkImageCreateFlagBits;
+typedef VkFlags VkImageCreateFlags;
+
+typedef enum VkSampleCountFlagBits {
+ VK_SAMPLE_COUNT_1_BIT = 0x00000001,
+ VK_SAMPLE_COUNT_2_BIT = 0x00000002,
+ VK_SAMPLE_COUNT_4_BIT = 0x00000004,
+ VK_SAMPLE_COUNT_8_BIT = 0x00000008,
+ VK_SAMPLE_COUNT_16_BIT = 0x00000010,
+ VK_SAMPLE_COUNT_32_BIT = 0x00000020,
+ VK_SAMPLE_COUNT_64_BIT = 0x00000040,
+ VK_SAMPLE_COUNT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkSampleCountFlagBits;
+typedef VkFlags VkSampleCountFlags;
+
+typedef enum VkQueueFlagBits {
+ VK_QUEUE_GRAPHICS_BIT = 0x00000001,
+ VK_QUEUE_COMPUTE_BIT = 0x00000002,
+ VK_QUEUE_TRANSFER_BIT = 0x00000004,
+ VK_QUEUE_SPARSE_BINDING_BIT = 0x00000008,
+ VK_QUEUE_PROTECTED_BIT = 0x00000010,
+ VK_QUEUE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkQueueFlagBits;
+typedef VkFlags VkQueueFlags;
+
+typedef enum VkMemoryPropertyFlagBits {
+ VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT = 0x00000001,
+ VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT = 0x00000002,
+ VK_MEMORY_PROPERTY_HOST_COHERENT_BIT = 0x00000004,
+ VK_MEMORY_PROPERTY_HOST_CACHED_BIT = 0x00000008,
+ VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT = 0x00000010,
+ VK_MEMORY_PROPERTY_PROTECTED_BIT = 0x00000020,
+ VK_MEMORY_PROPERTY_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkMemoryPropertyFlagBits;
+typedef VkFlags VkMemoryPropertyFlags;
+
+typedef enum VkMemoryHeapFlagBits {
+ VK_MEMORY_HEAP_DEVICE_LOCAL_BIT = 0x00000001,
+ VK_MEMORY_HEAP_MULTI_INSTANCE_BIT = 0x00000002,
+ VK_MEMORY_HEAP_MULTI_INSTANCE_BIT_KHR = VK_MEMORY_HEAP_MULTI_INSTANCE_BIT,
+ VK_MEMORY_HEAP_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkMemoryHeapFlagBits;
+typedef VkFlags VkMemoryHeapFlags;
+typedef VkFlags VkDeviceCreateFlags;
+
+typedef enum VkDeviceQueueCreateFlagBits {
+ VK_DEVICE_QUEUE_CREATE_PROTECTED_BIT = 0x00000001,
+ VK_DEVICE_QUEUE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkDeviceQueueCreateFlagBits;
+typedef VkFlags VkDeviceQueueCreateFlags;
+
+typedef enum VkPipelineStageFlagBits {
+ VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT = 0x00000001,
+ VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT = 0x00000002,
+ VK_PIPELINE_STAGE_VERTEX_INPUT_BIT = 0x00000004,
+ VK_PIPELINE_STAGE_VERTEX_SHADER_BIT = 0x00000008,
+ VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT = 0x00000010,
+ VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT = 0x00000020,
+ VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT = 0x00000040,
+ VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT = 0x00000080,
+ VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT = 0x00000100,
+ VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT = 0x00000200,
+ VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT = 0x00000400,
+ VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT = 0x00000800,
+ VK_PIPELINE_STAGE_TRANSFER_BIT = 0x00001000,
+ VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT = 0x00002000,
+ VK_PIPELINE_STAGE_HOST_BIT = 0x00004000,
+ VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT = 0x00008000,
+ VK_PIPELINE_STAGE_ALL_COMMANDS_BIT = 0x00010000,
+ VK_PIPELINE_STAGE_COMMAND_PROCESS_BIT_NVX = 0x00020000,
+ VK_PIPELINE_STAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkPipelineStageFlagBits;
+typedef VkFlags VkPipelineStageFlags;
+typedef VkFlags VkMemoryMapFlags;
+
+typedef enum VkImageAspectFlagBits {
+ VK_IMAGE_ASPECT_COLOR_BIT = 0x00000001,
+ VK_IMAGE_ASPECT_DEPTH_BIT = 0x00000002,
+ VK_IMAGE_ASPECT_STENCIL_BIT = 0x00000004,
+ VK_IMAGE_ASPECT_METADATA_BIT = 0x00000008,
+ VK_IMAGE_ASPECT_PLANE_0_BIT = 0x00000010,
+ VK_IMAGE_ASPECT_PLANE_1_BIT = 0x00000020,
+ VK_IMAGE_ASPECT_PLANE_2_BIT = 0x00000040,
+ VK_IMAGE_ASPECT_PLANE_0_BIT_KHR = VK_IMAGE_ASPECT_PLANE_0_BIT,
+ VK_IMAGE_ASPECT_PLANE_1_BIT_KHR = VK_IMAGE_ASPECT_PLANE_1_BIT,
+ VK_IMAGE_ASPECT_PLANE_2_BIT_KHR = VK_IMAGE_ASPECT_PLANE_2_BIT,
+ VK_IMAGE_ASPECT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkImageAspectFlagBits;
+typedef VkFlags VkImageAspectFlags;
+
+typedef enum VkSparseImageFormatFlagBits {
+ VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT = 0x00000001,
+ VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT = 0x00000002,
+ VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT = 0x00000004,
+ VK_SPARSE_IMAGE_FORMAT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkSparseImageFormatFlagBits;
+typedef VkFlags VkSparseImageFormatFlags;
+
+typedef enum VkSparseMemoryBindFlagBits {
+ VK_SPARSE_MEMORY_BIND_METADATA_BIT = 0x00000001,
+ VK_SPARSE_MEMORY_BIND_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkSparseMemoryBindFlagBits;
+typedef VkFlags VkSparseMemoryBindFlags;
+
+typedef enum VkFenceCreateFlagBits {
+ VK_FENCE_CREATE_SIGNALED_BIT = 0x00000001,
+ VK_FENCE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkFenceCreateFlagBits;
+typedef VkFlags VkFenceCreateFlags;
+typedef VkFlags VkSemaphoreCreateFlags;
+typedef VkFlags VkEventCreateFlags;
+typedef VkFlags VkQueryPoolCreateFlags;
+
+typedef enum VkQueryPipelineStatisticFlagBits {
+ VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT = 0x00000001,
+ VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT = 0x00000002,
+ VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT = 0x00000004,
+ VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT = 0x00000008,
+ VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT = 0x00000010,
+ VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT = 0x00000020,
+ VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT = 0x00000040,
+ VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT = 0x00000080,
+ VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT = 0x00000100,
+ VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT = 0x00000200,
+ VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT = 0x00000400,
+ VK_QUERY_PIPELINE_STATISTIC_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkQueryPipelineStatisticFlagBits;
+typedef VkFlags VkQueryPipelineStatisticFlags;
+
+typedef enum VkQueryResultFlagBits {
+ VK_QUERY_RESULT_64_BIT = 0x00000001,
+ VK_QUERY_RESULT_WAIT_BIT = 0x00000002,
+ VK_QUERY_RESULT_WITH_AVAILABILITY_BIT = 0x00000004,
+ VK_QUERY_RESULT_PARTIAL_BIT = 0x00000008,
+ VK_QUERY_RESULT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkQueryResultFlagBits;
+typedef VkFlags VkQueryResultFlags;
+
+typedef enum VkBufferCreateFlagBits {
+ VK_BUFFER_CREATE_SPARSE_BINDING_BIT = 0x00000001,
+ VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT = 0x00000002,
+ VK_BUFFER_CREATE_SPARSE_ALIASED_BIT = 0x00000004,
+ VK_BUFFER_CREATE_PROTECTED_BIT = 0x00000008,
+ VK_BUFFER_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkBufferCreateFlagBits;
+typedef VkFlags VkBufferCreateFlags;
+
+typedef enum VkBufferUsageFlagBits {
+ VK_BUFFER_USAGE_TRANSFER_SRC_BIT = 0x00000001,
+ VK_BUFFER_USAGE_TRANSFER_DST_BIT = 0x00000002,
+ VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT = 0x00000004,
+ VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT = 0x00000008,
+ VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT = 0x00000010,
+ VK_BUFFER_USAGE_STORAGE_BUFFER_BIT = 0x00000020,
+ VK_BUFFER_USAGE_INDEX_BUFFER_BIT = 0x00000040,
+ VK_BUFFER_USAGE_VERTEX_BUFFER_BIT = 0x00000080,
+ VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT = 0x00000100,
+ VK_BUFFER_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkBufferUsageFlagBits;
+typedef VkFlags VkBufferUsageFlags;
+typedef VkFlags VkBufferViewCreateFlags;
+typedef VkFlags VkImageViewCreateFlags;
+typedef VkFlags VkShaderModuleCreateFlags;
+typedef VkFlags VkPipelineCacheCreateFlags;
+
+typedef enum VkPipelineCreateFlagBits {
+ VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT = 0x00000001,
+ VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT = 0x00000002,
+ VK_PIPELINE_CREATE_DERIVATIVE_BIT = 0x00000004,
+ VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT = 0x00000008,
+ VK_PIPELINE_CREATE_DISPATCH_BASE = 0x00000010,
+ VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT_KHR = VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT,
+ VK_PIPELINE_CREATE_DISPATCH_BASE_KHR = VK_PIPELINE_CREATE_DISPATCH_BASE,
+ VK_PIPELINE_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkPipelineCreateFlagBits;
+typedef VkFlags VkPipelineCreateFlags;
+typedef VkFlags VkPipelineShaderStageCreateFlags;
+
+typedef enum VkShaderStageFlagBits {
+ VK_SHADER_STAGE_VERTEX_BIT = 0x00000001,
+ VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT = 0x00000002,
+ VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT = 0x00000004,
+ VK_SHADER_STAGE_GEOMETRY_BIT = 0x00000008,
+ VK_SHADER_STAGE_FRAGMENT_BIT = 0x00000010,
+ VK_SHADER_STAGE_COMPUTE_BIT = 0x00000020,
+ VK_SHADER_STAGE_ALL_GRAPHICS = 0x0000001F,
+ VK_SHADER_STAGE_ALL = 0x7FFFFFFF,
+ VK_SHADER_STAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkShaderStageFlagBits;
+typedef VkFlags VkPipelineVertexInputStateCreateFlags;
+typedef VkFlags VkPipelineInputAssemblyStateCreateFlags;
+typedef VkFlags VkPipelineTessellationStateCreateFlags;
+typedef VkFlags VkPipelineViewportStateCreateFlags;
+typedef VkFlags VkPipelineRasterizationStateCreateFlags;
+
+typedef enum VkCullModeFlagBits {
+ VK_CULL_MODE_NONE = 0,
+ VK_CULL_MODE_FRONT_BIT = 0x00000001,
+ VK_CULL_MODE_BACK_BIT = 0x00000002,
+ VK_CULL_MODE_FRONT_AND_BACK = 0x00000003,
+ VK_CULL_MODE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkCullModeFlagBits;
+typedef VkFlags VkCullModeFlags;
+typedef VkFlags VkPipelineMultisampleStateCreateFlags;
+typedef VkFlags VkPipelineDepthStencilStateCreateFlags;
+typedef VkFlags VkPipelineColorBlendStateCreateFlags;
+
+typedef enum VkColorComponentFlagBits {
+ VK_COLOR_COMPONENT_R_BIT = 0x00000001,
+ VK_COLOR_COMPONENT_G_BIT = 0x00000002,
+ VK_COLOR_COMPONENT_B_BIT = 0x00000004,
+ VK_COLOR_COMPONENT_A_BIT = 0x00000008,
+ VK_COLOR_COMPONENT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkColorComponentFlagBits;
+typedef VkFlags VkColorComponentFlags;
+typedef VkFlags VkPipelineDynamicStateCreateFlags;
+typedef VkFlags VkPipelineLayoutCreateFlags;
+typedef VkFlags VkShaderStageFlags;
+typedef VkFlags VkSamplerCreateFlags;
+
+typedef enum VkDescriptorSetLayoutCreateFlagBits {
+ VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR = 0x00000001,
+ VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT = 0x00000002,
+ VK_DESCRIPTOR_SET_LAYOUT_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkDescriptorSetLayoutCreateFlagBits;
+typedef VkFlags VkDescriptorSetLayoutCreateFlags;
+
+typedef enum VkDescriptorPoolCreateFlagBits {
+ VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT = 0x00000001,
+ VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT = 0x00000002,
+ VK_DESCRIPTOR_POOL_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkDescriptorPoolCreateFlagBits;
+typedef VkFlags VkDescriptorPoolCreateFlags;
+typedef VkFlags VkDescriptorPoolResetFlags;
+typedef VkFlags VkFramebufferCreateFlags;
+typedef VkFlags VkRenderPassCreateFlags;
+
+typedef enum VkAttachmentDescriptionFlagBits {
+ VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT = 0x00000001,
+ VK_ATTACHMENT_DESCRIPTION_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkAttachmentDescriptionFlagBits;
+typedef VkFlags VkAttachmentDescriptionFlags;
+
+typedef enum VkSubpassDescriptionFlagBits {
+ VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX = 0x00000001,
+ VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX = 0x00000002,
+ VK_SUBPASS_DESCRIPTION_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkSubpassDescriptionFlagBits;
+typedef VkFlags VkSubpassDescriptionFlags;
+
+typedef enum VkAccessFlagBits {
+ VK_ACCESS_INDIRECT_COMMAND_READ_BIT = 0x00000001,
+ VK_ACCESS_INDEX_READ_BIT = 0x00000002,
+ VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT = 0x00000004,
+ VK_ACCESS_UNIFORM_READ_BIT = 0x00000008,
+ VK_ACCESS_INPUT_ATTACHMENT_READ_BIT = 0x00000010,
+ VK_ACCESS_SHADER_READ_BIT = 0x00000020,
+ VK_ACCESS_SHADER_WRITE_BIT = 0x00000040,
+ VK_ACCESS_COLOR_ATTACHMENT_READ_BIT = 0x00000080,
+ VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT = 0x00000100,
+ VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT = 0x00000200,
+ VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT = 0x00000400,
+ VK_ACCESS_TRANSFER_READ_BIT = 0x00000800,
+ VK_ACCESS_TRANSFER_WRITE_BIT = 0x00001000,
+ VK_ACCESS_HOST_READ_BIT = 0x00002000,
+ VK_ACCESS_HOST_WRITE_BIT = 0x00004000,
+ VK_ACCESS_MEMORY_READ_BIT = 0x00008000,
+ VK_ACCESS_MEMORY_WRITE_BIT = 0x00010000,
+ VK_ACCESS_COMMAND_PROCESS_READ_BIT_NVX = 0x00020000,
+ VK_ACCESS_COMMAND_PROCESS_WRITE_BIT_NVX = 0x00040000,
+ VK_ACCESS_COLOR_ATTACHMENT_READ_NONCOHERENT_BIT_EXT = 0x00080000,
+ VK_ACCESS_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkAccessFlagBits;
+typedef VkFlags VkAccessFlags;
+
+typedef enum VkDependencyFlagBits {
+ VK_DEPENDENCY_BY_REGION_BIT = 0x00000001,
+ VK_DEPENDENCY_DEVICE_GROUP_BIT = 0x00000004,
+ VK_DEPENDENCY_VIEW_LOCAL_BIT = 0x00000002,
+ VK_DEPENDENCY_VIEW_LOCAL_BIT_KHR = VK_DEPENDENCY_VIEW_LOCAL_BIT,
+ VK_DEPENDENCY_DEVICE_GROUP_BIT_KHR = VK_DEPENDENCY_DEVICE_GROUP_BIT,
+ VK_DEPENDENCY_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkDependencyFlagBits;
+typedef VkFlags VkDependencyFlags;
+
+typedef enum VkCommandPoolCreateFlagBits {
+ VK_COMMAND_POOL_CREATE_TRANSIENT_BIT = 0x00000001,
+ VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT = 0x00000002,
+ VK_COMMAND_POOL_CREATE_PROTECTED_BIT = 0x00000004,
+ VK_COMMAND_POOL_CREATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkCommandPoolCreateFlagBits;
+typedef VkFlags VkCommandPoolCreateFlags;
+
+typedef enum VkCommandPoolResetFlagBits {
+ VK_COMMAND_POOL_RESET_RELEASE_RESOURCES_BIT = 0x00000001,
+ VK_COMMAND_POOL_RESET_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkCommandPoolResetFlagBits;
+typedef VkFlags VkCommandPoolResetFlags;
+
+typedef enum VkCommandBufferUsageFlagBits {
+ VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT = 0x00000001,
+ VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT = 0x00000002,
+ VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT = 0x00000004,
+ VK_COMMAND_BUFFER_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkCommandBufferUsageFlagBits;
+typedef VkFlags VkCommandBufferUsageFlags;
+
+typedef enum VkQueryControlFlagBits {
+ VK_QUERY_CONTROL_PRECISE_BIT = 0x00000001,
+ VK_QUERY_CONTROL_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkQueryControlFlagBits;
+typedef VkFlags VkQueryControlFlags;
+
+typedef enum VkCommandBufferResetFlagBits {
+ VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT = 0x00000001,
+ VK_COMMAND_BUFFER_RESET_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkCommandBufferResetFlagBits;
+typedef VkFlags VkCommandBufferResetFlags;
+
+typedef enum VkStencilFaceFlagBits {
+ VK_STENCIL_FACE_FRONT_BIT = 0x00000001,
+ VK_STENCIL_FACE_BACK_BIT = 0x00000002,
+ VK_STENCIL_FRONT_AND_BACK = 0x00000003,
+ VK_STENCIL_FACE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkStencilFaceFlagBits;
+typedef VkFlags VkStencilFaceFlags;
+
+typedef struct VkApplicationInfo {
+ VkStructureType sType;
+ const void* pNext;
+ const char* pApplicationName;
+ uint32_t applicationVersion;
+ const char* pEngineName;
+ uint32_t engineVersion;
+ uint32_t apiVersion;
+} VkApplicationInfo;
+
+typedef struct VkInstanceCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkInstanceCreateFlags flags;
+ const VkApplicationInfo* pApplicationInfo;
+ uint32_t enabledLayerCount;
+ const char* const* ppEnabledLayerNames;
+ uint32_t enabledExtensionCount;
+ const char* const* ppEnabledExtensionNames;
+} VkInstanceCreateInfo;
+
+typedef void* (VKAPI_PTR *PFN_vkAllocationFunction)(
+ void* pUserData,
+ size_t size,
+ size_t alignment,
+ VkSystemAllocationScope allocationScope);
+
+typedef void* (VKAPI_PTR *PFN_vkReallocationFunction)(
+ void* pUserData,
+ void* pOriginal,
+ size_t size,
+ size_t alignment,
+ VkSystemAllocationScope allocationScope);
+
+typedef void (VKAPI_PTR *PFN_vkFreeFunction)(
+ void* pUserData,
+ void* pMemory);
+
+typedef void (VKAPI_PTR *PFN_vkInternalAllocationNotification)(
+ void* pUserData,
+ size_t size,
+ VkInternalAllocationType allocationType,
+ VkSystemAllocationScope allocationScope);
+
+typedef void (VKAPI_PTR *PFN_vkInternalFreeNotification)(
+ void* pUserData,
+ size_t size,
+ VkInternalAllocationType allocationType,
+ VkSystemAllocationScope allocationScope);
+
+typedef struct VkAllocationCallbacks {
+ void* pUserData;
+ PFN_vkAllocationFunction pfnAllocation;
+ PFN_vkReallocationFunction pfnReallocation;
+ PFN_vkFreeFunction pfnFree;
+ PFN_vkInternalAllocationNotification pfnInternalAllocation;
+ PFN_vkInternalFreeNotification pfnInternalFree;
+} VkAllocationCallbacks;
+
+typedef struct VkPhysicalDeviceFeatures {
+ VkBool32 robustBufferAccess;
+ VkBool32 fullDrawIndexUint32;
+ VkBool32 imageCubeArray;
+ VkBool32 independentBlend;
+ VkBool32 geometryShader;
+ VkBool32 tessellationShader;
+ VkBool32 sampleRateShading;
+ VkBool32 dualSrcBlend;
+ VkBool32 logicOp;
+ VkBool32 multiDrawIndirect;
+ VkBool32 drawIndirectFirstInstance;
+ VkBool32 depthClamp;
+ VkBool32 depthBiasClamp;
+ VkBool32 fillModeNonSolid;
+ VkBool32 depthBounds;
+ VkBool32 wideLines;
+ VkBool32 largePoints;
+ VkBool32 alphaToOne;
+ VkBool32 multiViewport;
+ VkBool32 samplerAnisotropy;
+ VkBool32 textureCompressionETC2;
+ VkBool32 textureCompressionASTC_LDR;
+ VkBool32 textureCompressionBC;
+ VkBool32 occlusionQueryPrecise;
+ VkBool32 pipelineStatisticsQuery;
+ VkBool32 vertexPipelineStoresAndAtomics;
+ VkBool32 fragmentStoresAndAtomics;
+ VkBool32 shaderTessellationAndGeometryPointSize;
+ VkBool32 shaderImageGatherExtended;
+ VkBool32 shaderStorageImageExtendedFormats;
+ VkBool32 shaderStorageImageMultisample;
+ VkBool32 shaderStorageImageReadWithoutFormat;
+ VkBool32 shaderStorageImageWriteWithoutFormat;
+ VkBool32 shaderUniformBufferArrayDynamicIndexing;
+ VkBool32 shaderSampledImageArrayDynamicIndexing;
+ VkBool32 shaderStorageBufferArrayDynamicIndexing;
+ VkBool32 shaderStorageImageArrayDynamicIndexing;
+ VkBool32 shaderClipDistance;
+ VkBool32 shaderCullDistance;
+ VkBool32 shaderFloat64;
+ VkBool32 shaderInt64;
+ VkBool32 shaderInt16;
+ VkBool32 shaderResourceResidency;
+ VkBool32 shaderResourceMinLod;
+ VkBool32 sparseBinding;
+ VkBool32 sparseResidencyBuffer;
+ VkBool32 sparseResidencyImage2D;
+ VkBool32 sparseResidencyImage3D;
+ VkBool32 sparseResidency2Samples;
+ VkBool32 sparseResidency4Samples;
+ VkBool32 sparseResidency8Samples;
+ VkBool32 sparseResidency16Samples;
+ VkBool32 sparseResidencyAliased;
+ VkBool32 variableMultisampleRate;
+ VkBool32 inheritedQueries;
+} VkPhysicalDeviceFeatures;
+
+typedef struct VkFormatProperties {
+ VkFormatFeatureFlags linearTilingFeatures;
+ VkFormatFeatureFlags optimalTilingFeatures;
+ VkFormatFeatureFlags bufferFeatures;
+} VkFormatProperties;
+
+typedef struct VkExtent3D {
+ uint32_t width;
+ uint32_t height;
+ uint32_t depth;
+} VkExtent3D;
+
+typedef struct VkImageFormatProperties {
+ VkExtent3D maxExtent;
+ uint32_t maxMipLevels;
+ uint32_t maxArrayLayers;
+ VkSampleCountFlags sampleCounts;
+ VkDeviceSize maxResourceSize;
+} VkImageFormatProperties;
+
+typedef struct VkPhysicalDeviceLimits {
+ uint32_t maxImageDimension1D;
+ uint32_t maxImageDimension2D;
+ uint32_t maxImageDimension3D;
+ uint32_t maxImageDimensionCube;
+ uint32_t maxImageArrayLayers;
+ uint32_t maxTexelBufferElements;
+ uint32_t maxUniformBufferRange;
+ uint32_t maxStorageBufferRange;
+ uint32_t maxPushConstantsSize;
+ uint32_t maxMemoryAllocationCount;
+ uint32_t maxSamplerAllocationCount;
+ VkDeviceSize bufferImageGranularity;
+ VkDeviceSize sparseAddressSpaceSize;
+ uint32_t maxBoundDescriptorSets;
+ uint32_t maxPerStageDescriptorSamplers;
+ uint32_t maxPerStageDescriptorUniformBuffers;
+ uint32_t maxPerStageDescriptorStorageBuffers;
+ uint32_t maxPerStageDescriptorSampledImages;
+ uint32_t maxPerStageDescriptorStorageImages;
+ uint32_t maxPerStageDescriptorInputAttachments;
+ uint32_t maxPerStageResources;
+ uint32_t maxDescriptorSetSamplers;
+ uint32_t maxDescriptorSetUniformBuffers;
+ uint32_t maxDescriptorSetUniformBuffersDynamic;
+ uint32_t maxDescriptorSetStorageBuffers;
+ uint32_t maxDescriptorSetStorageBuffersDynamic;
+ uint32_t maxDescriptorSetSampledImages;
+ uint32_t maxDescriptorSetStorageImages;
+ uint32_t maxDescriptorSetInputAttachments;
+ uint32_t maxVertexInputAttributes;
+ uint32_t maxVertexInputBindings;
+ uint32_t maxVertexInputAttributeOffset;
+ uint32_t maxVertexInputBindingStride;
+ uint32_t maxVertexOutputComponents;
+ uint32_t maxTessellationGenerationLevel;
+ uint32_t maxTessellationPatchSize;
+ uint32_t maxTessellationControlPerVertexInputComponents;
+ uint32_t maxTessellationControlPerVertexOutputComponents;
+ uint32_t maxTessellationControlPerPatchOutputComponents;
+ uint32_t maxTessellationControlTotalOutputComponents;
+ uint32_t maxTessellationEvaluationInputComponents;
+ uint32_t maxTessellationEvaluationOutputComponents;
+ uint32_t maxGeometryShaderInvocations;
+ uint32_t maxGeometryInputComponents;
+ uint32_t maxGeometryOutputComponents;
+ uint32_t maxGeometryOutputVertices;
+ uint32_t maxGeometryTotalOutputComponents;
+ uint32_t maxFragmentInputComponents;
+ uint32_t maxFragmentOutputAttachments;
+ uint32_t maxFragmentDualSrcAttachments;
+ uint32_t maxFragmentCombinedOutputResources;
+ uint32_t maxComputeSharedMemorySize;
+ uint32_t maxComputeWorkGroupCount[3];
+ uint32_t maxComputeWorkGroupInvocations;
+ uint32_t maxComputeWorkGroupSize[3];
+ uint32_t subPixelPrecisionBits;
+ uint32_t subTexelPrecisionBits;
+ uint32_t mipmapPrecisionBits;
+ uint32_t maxDrawIndexedIndexValue;
+ uint32_t maxDrawIndirectCount;
+ float maxSamplerLodBias;
+ float maxSamplerAnisotropy;
+ uint32_t maxViewports;
+ uint32_t maxViewportDimensions[2];
+ float viewportBoundsRange[2];
+ uint32_t viewportSubPixelBits;
+ size_t minMemoryMapAlignment;
+ VkDeviceSize minTexelBufferOffsetAlignment;
+ VkDeviceSize minUniformBufferOffsetAlignment;
+ VkDeviceSize minStorageBufferOffsetAlignment;
+ int32_t minTexelOffset;
+ uint32_t maxTexelOffset;
+ int32_t minTexelGatherOffset;
+ uint32_t maxTexelGatherOffset;
+ float minInterpolationOffset;
+ float maxInterpolationOffset;
+ uint32_t subPixelInterpolationOffsetBits;
+ uint32_t maxFramebufferWidth;
+ uint32_t maxFramebufferHeight;
+ uint32_t maxFramebufferLayers;
+ VkSampleCountFlags framebufferColorSampleCounts;
+ VkSampleCountFlags framebufferDepthSampleCounts;
+ VkSampleCountFlags framebufferStencilSampleCounts;
+ VkSampleCountFlags framebufferNoAttachmentsSampleCounts;
+ uint32_t maxColorAttachments;
+ VkSampleCountFlags sampledImageColorSampleCounts;
+ VkSampleCountFlags sampledImageIntegerSampleCounts;
+ VkSampleCountFlags sampledImageDepthSampleCounts;
+ VkSampleCountFlags sampledImageStencilSampleCounts;
+ VkSampleCountFlags storageImageSampleCounts;
+ uint32_t maxSampleMaskWords;
+ VkBool32 timestampComputeAndGraphics;
+ float timestampPeriod;
+ uint32_t maxClipDistances;
+ uint32_t maxCullDistances;
+ uint32_t maxCombinedClipAndCullDistances;
+ uint32_t discreteQueuePriorities;
+ float pointSizeRange[2];
+ float lineWidthRange[2];
+ float pointSizeGranularity;
+ float lineWidthGranularity;
+ VkBool32 strictLines;
+ VkBool32 standardSampleLocations;
+ VkDeviceSize optimalBufferCopyOffsetAlignment;
+ VkDeviceSize optimalBufferCopyRowPitchAlignment;
+ VkDeviceSize nonCoherentAtomSize;
+} VkPhysicalDeviceLimits;
+
+typedef struct VkPhysicalDeviceSparseProperties {
+ VkBool32 residencyStandard2DBlockShape;
+ VkBool32 residencyStandard2DMultisampleBlockShape;
+ VkBool32 residencyStandard3DBlockShape;
+ VkBool32 residencyAlignedMipSize;
+ VkBool32 residencyNonResidentStrict;
+} VkPhysicalDeviceSparseProperties;
+
+typedef struct VkPhysicalDeviceProperties {
+ uint32_t apiVersion;
+ uint32_t driverVersion;
+ uint32_t vendorID;
+ uint32_t deviceID;
+ VkPhysicalDeviceType deviceType;
+ char deviceName[VK_MAX_PHYSICAL_DEVICE_NAME_SIZE];
+ uint8_t pipelineCacheUUID[VK_UUID_SIZE];
+ VkPhysicalDeviceLimits limits;
+ VkPhysicalDeviceSparseProperties sparseProperties;
+} VkPhysicalDeviceProperties;
+
+typedef struct VkQueueFamilyProperties {
+ VkQueueFlags queueFlags;
+ uint32_t queueCount;
+ uint32_t timestampValidBits;
+ VkExtent3D minImageTransferGranularity;
+} VkQueueFamilyProperties;
+
+typedef struct VkMemoryType {
+ VkMemoryPropertyFlags propertyFlags;
+ uint32_t heapIndex;
+} VkMemoryType;
+
+typedef struct VkMemoryHeap {
+ VkDeviceSize size;
+ VkMemoryHeapFlags flags;
+} VkMemoryHeap;
+
+typedef struct VkPhysicalDeviceMemoryProperties {
+ uint32_t memoryTypeCount;
+ VkMemoryType memoryTypes[VK_MAX_MEMORY_TYPES];
+ uint32_t memoryHeapCount;
+ VkMemoryHeap memoryHeaps[VK_MAX_MEMORY_HEAPS];
+} VkPhysicalDeviceMemoryProperties;
+
+typedef void (VKAPI_PTR *PFN_vkVoidFunction)(void);
+typedef struct VkDeviceQueueCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceQueueCreateFlags flags;
+ uint32_t queueFamilyIndex;
+ uint32_t queueCount;
+ const float* pQueuePriorities;
+} VkDeviceQueueCreateInfo;
+
+typedef struct VkDeviceCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceCreateFlags flags;
+ uint32_t queueCreateInfoCount;
+ const VkDeviceQueueCreateInfo* pQueueCreateInfos;
+ uint32_t enabledLayerCount;
+ const char* const* ppEnabledLayerNames;
+ uint32_t enabledExtensionCount;
+ const char* const* ppEnabledExtensionNames;
+ const VkPhysicalDeviceFeatures* pEnabledFeatures;
+} VkDeviceCreateInfo;
+
+typedef struct VkExtensionProperties {
+ char extensionName[VK_MAX_EXTENSION_NAME_SIZE];
+ uint32_t specVersion;
+} VkExtensionProperties;
+
+typedef struct VkLayerProperties {
+ char layerName[VK_MAX_EXTENSION_NAME_SIZE];
+ uint32_t specVersion;
+ uint32_t implementationVersion;
+ char description[VK_MAX_DESCRIPTION_SIZE];
+} VkLayerProperties;
+
+typedef struct VkSubmitInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t waitSemaphoreCount;
+ const VkSemaphore* pWaitSemaphores;
+ const VkPipelineStageFlags* pWaitDstStageMask;
+ uint32_t commandBufferCount;
+ const VkCommandBuffer* pCommandBuffers;
+ uint32_t signalSemaphoreCount;
+ const VkSemaphore* pSignalSemaphores;
+} VkSubmitInfo;
+
+typedef struct VkMemoryAllocateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceSize allocationSize;
+ uint32_t memoryTypeIndex;
+} VkMemoryAllocateInfo;
+
+typedef struct VkMappedMemoryRange {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceMemory memory;
+ VkDeviceSize offset;
+ VkDeviceSize size;
+} VkMappedMemoryRange;
+
+typedef struct VkMemoryRequirements {
+ VkDeviceSize size;
+ VkDeviceSize alignment;
+ uint32_t memoryTypeBits;
+} VkMemoryRequirements;
+
+typedef struct VkSparseImageFormatProperties {
+ VkImageAspectFlags aspectMask;
+ VkExtent3D imageGranularity;
+ VkSparseImageFormatFlags flags;
+} VkSparseImageFormatProperties;
+
+typedef struct VkSparseImageMemoryRequirements {
+ VkSparseImageFormatProperties formatProperties;
+ uint32_t imageMipTailFirstLod;
+ VkDeviceSize imageMipTailSize;
+ VkDeviceSize imageMipTailOffset;
+ VkDeviceSize imageMipTailStride;
+} VkSparseImageMemoryRequirements;
+
+typedef struct VkSparseMemoryBind {
+ VkDeviceSize resourceOffset;
+ VkDeviceSize size;
+ VkDeviceMemory memory;
+ VkDeviceSize memoryOffset;
+ VkSparseMemoryBindFlags flags;
+} VkSparseMemoryBind;
+
+typedef struct VkSparseBufferMemoryBindInfo {
+ VkBuffer buffer;
+ uint32_t bindCount;
+ const VkSparseMemoryBind* pBinds;
+} VkSparseBufferMemoryBindInfo;
+
+typedef struct VkSparseImageOpaqueMemoryBindInfo {
+ VkImage image;
+ uint32_t bindCount;
+ const VkSparseMemoryBind* pBinds;
+} VkSparseImageOpaqueMemoryBindInfo;
+
+typedef struct VkImageSubresource {
+ VkImageAspectFlags aspectMask;
+ uint32_t mipLevel;
+ uint32_t arrayLayer;
+} VkImageSubresource;
+
+typedef struct VkOffset3D {
+ int32_t x;
+ int32_t y;
+ int32_t z;
+} VkOffset3D;
+
+typedef struct VkSparseImageMemoryBind {
+ VkImageSubresource subresource;
+ VkOffset3D offset;
+ VkExtent3D extent;
+ VkDeviceMemory memory;
+ VkDeviceSize memoryOffset;
+ VkSparseMemoryBindFlags flags;
+} VkSparseImageMemoryBind;
+
+typedef struct VkSparseImageMemoryBindInfo {
+ VkImage image;
+ uint32_t bindCount;
+ const VkSparseImageMemoryBind* pBinds;
+} VkSparseImageMemoryBindInfo;
+
+typedef struct VkBindSparseInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t waitSemaphoreCount;
+ const VkSemaphore* pWaitSemaphores;
+ uint32_t bufferBindCount;
+ const VkSparseBufferMemoryBindInfo* pBufferBinds;
+ uint32_t imageOpaqueBindCount;
+ const VkSparseImageOpaqueMemoryBindInfo* pImageOpaqueBinds;
+ uint32_t imageBindCount;
+ const VkSparseImageMemoryBindInfo* pImageBinds;
+ uint32_t signalSemaphoreCount;
+ const VkSemaphore* pSignalSemaphores;
+} VkBindSparseInfo;
+
+typedef struct VkFenceCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkFenceCreateFlags flags;
+} VkFenceCreateInfo;
+
+typedef struct VkSemaphoreCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkSemaphoreCreateFlags flags;
+} VkSemaphoreCreateInfo;
+
+typedef struct VkEventCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkEventCreateFlags flags;
+} VkEventCreateInfo;
+
+typedef struct VkQueryPoolCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkQueryPoolCreateFlags flags;
+ VkQueryType queryType;
+ uint32_t queryCount;
+ VkQueryPipelineStatisticFlags pipelineStatistics;
+} VkQueryPoolCreateInfo;
+
+typedef struct VkBufferCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkBufferCreateFlags flags;
+ VkDeviceSize size;
+ VkBufferUsageFlags usage;
+ VkSharingMode sharingMode;
+ uint32_t queueFamilyIndexCount;
+ const uint32_t* pQueueFamilyIndices;
+} VkBufferCreateInfo;
+
+typedef struct VkBufferViewCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkBufferViewCreateFlags flags;
+ VkBuffer buffer;
+ VkFormat format;
+ VkDeviceSize offset;
+ VkDeviceSize range;
+} VkBufferViewCreateInfo;
+
+typedef struct VkImageCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImageCreateFlags flags;
+ VkImageType imageType;
+ VkFormat format;
+ VkExtent3D extent;
+ uint32_t mipLevels;
+ uint32_t arrayLayers;
+ VkSampleCountFlagBits samples;
+ VkImageTiling tiling;
+ VkImageUsageFlags usage;
+ VkSharingMode sharingMode;
+ uint32_t queueFamilyIndexCount;
+ const uint32_t* pQueueFamilyIndices;
+ VkImageLayout initialLayout;
+} VkImageCreateInfo;
+
+typedef struct VkSubresourceLayout {
+ VkDeviceSize offset;
+ VkDeviceSize size;
+ VkDeviceSize rowPitch;
+ VkDeviceSize arrayPitch;
+ VkDeviceSize depthPitch;
+} VkSubresourceLayout;
+
+typedef struct VkComponentMapping {
+ VkComponentSwizzle r;
+ VkComponentSwizzle g;
+ VkComponentSwizzle b;
+ VkComponentSwizzle a;
+} VkComponentMapping;
+
+typedef struct VkImageSubresourceRange {
+ VkImageAspectFlags aspectMask;
+ uint32_t baseMipLevel;
+ uint32_t levelCount;
+ uint32_t baseArrayLayer;
+ uint32_t layerCount;
+} VkImageSubresourceRange;
+
+typedef struct VkImageViewCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImageViewCreateFlags flags;
+ VkImage image;
+ VkImageViewType viewType;
+ VkFormat format;
+ VkComponentMapping components;
+ VkImageSubresourceRange subresourceRange;
+} VkImageViewCreateInfo;
+
+typedef struct VkShaderModuleCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkShaderModuleCreateFlags flags;
+ size_t codeSize;
+ const uint32_t* pCode;
+} VkShaderModuleCreateInfo;
+
+typedef struct VkPipelineCacheCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineCacheCreateFlags flags;
+ size_t initialDataSize;
+ const void* pInitialData;
+} VkPipelineCacheCreateInfo;
+
+typedef struct VkSpecializationMapEntry {
+ uint32_t constantID;
+ uint32_t offset;
+ size_t size;
+} VkSpecializationMapEntry;
+
+typedef struct VkSpecializationInfo {
+ uint32_t mapEntryCount;
+ const VkSpecializationMapEntry* pMapEntries;
+ size_t dataSize;
+ const void* pData;
+} VkSpecializationInfo;
+
+typedef struct VkPipelineShaderStageCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineShaderStageCreateFlags flags;
+ VkShaderStageFlagBits stage;
+ VkShaderModule module;
+ const char* pName;
+ const VkSpecializationInfo* pSpecializationInfo;
+} VkPipelineShaderStageCreateInfo;
+
+typedef struct VkVertexInputBindingDescription {
+ uint32_t binding;
+ uint32_t stride;
+ VkVertexInputRate inputRate;
+} VkVertexInputBindingDescription;
+
+typedef struct VkVertexInputAttributeDescription {
+ uint32_t location;
+ uint32_t binding;
+ VkFormat format;
+ uint32_t offset;
+} VkVertexInputAttributeDescription;
+
+typedef struct VkPipelineVertexInputStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineVertexInputStateCreateFlags flags;
+ uint32_t vertexBindingDescriptionCount;
+ const VkVertexInputBindingDescription* pVertexBindingDescriptions;
+ uint32_t vertexAttributeDescriptionCount;
+ const VkVertexInputAttributeDescription* pVertexAttributeDescriptions;
+} VkPipelineVertexInputStateCreateInfo;
+
+typedef struct VkPipelineInputAssemblyStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineInputAssemblyStateCreateFlags flags;
+ VkPrimitiveTopology topology;
+ VkBool32 primitiveRestartEnable;
+} VkPipelineInputAssemblyStateCreateInfo;
+
+typedef struct VkPipelineTessellationStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineTessellationStateCreateFlags flags;
+ uint32_t patchControlPoints;
+} VkPipelineTessellationStateCreateInfo;
+
+typedef struct VkViewport {
+ float x;
+ float y;
+ float width;
+ float height;
+ float minDepth;
+ float maxDepth;
+} VkViewport;
+
+typedef struct VkOffset2D {
+ int32_t x;
+ int32_t y;
+} VkOffset2D;
+
+typedef struct VkExtent2D {
+ uint32_t width;
+ uint32_t height;
+} VkExtent2D;
+
+typedef struct VkRect2D {
+ VkOffset2D offset;
+ VkExtent2D extent;
+} VkRect2D;
+
+typedef struct VkPipelineViewportStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineViewportStateCreateFlags flags;
+ uint32_t viewportCount;
+ const VkViewport* pViewports;
+ uint32_t scissorCount;
+ const VkRect2D* pScissors;
+} VkPipelineViewportStateCreateInfo;
+
+typedef struct VkPipelineRasterizationStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineRasterizationStateCreateFlags flags;
+ VkBool32 depthClampEnable;
+ VkBool32 rasterizerDiscardEnable;
+ VkPolygonMode polygonMode;
+ VkCullModeFlags cullMode;
+ VkFrontFace frontFace;
+ VkBool32 depthBiasEnable;
+ float depthBiasConstantFactor;
+ float depthBiasClamp;
+ float depthBiasSlopeFactor;
+ float lineWidth;
+} VkPipelineRasterizationStateCreateInfo;
+
+typedef struct VkPipelineMultisampleStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineMultisampleStateCreateFlags flags;
+ VkSampleCountFlagBits rasterizationSamples;
+ VkBool32 sampleShadingEnable;
+ float minSampleShading;
+ const VkSampleMask* pSampleMask;
+ VkBool32 alphaToCoverageEnable;
+ VkBool32 alphaToOneEnable;
+} VkPipelineMultisampleStateCreateInfo;
+
+typedef struct VkStencilOpState {
+ VkStencilOp failOp;
+ VkStencilOp passOp;
+ VkStencilOp depthFailOp;
+ VkCompareOp compareOp;
+ uint32_t compareMask;
+ uint32_t writeMask;
+ uint32_t reference;
+} VkStencilOpState;
+
+typedef struct VkPipelineDepthStencilStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineDepthStencilStateCreateFlags flags;
+ VkBool32 depthTestEnable;
+ VkBool32 depthWriteEnable;
+ VkCompareOp depthCompareOp;
+ VkBool32 depthBoundsTestEnable;
+ VkBool32 stencilTestEnable;
+ VkStencilOpState front;
+ VkStencilOpState back;
+ float minDepthBounds;
+ float maxDepthBounds;
+} VkPipelineDepthStencilStateCreateInfo;
+
+typedef struct VkPipelineColorBlendAttachmentState {
+ VkBool32 blendEnable;
+ VkBlendFactor srcColorBlendFactor;
+ VkBlendFactor dstColorBlendFactor;
+ VkBlendOp colorBlendOp;
+ VkBlendFactor srcAlphaBlendFactor;
+ VkBlendFactor dstAlphaBlendFactor;
+ VkBlendOp alphaBlendOp;
+ VkColorComponentFlags colorWriteMask;
+} VkPipelineColorBlendAttachmentState;
+
+typedef struct VkPipelineColorBlendStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineColorBlendStateCreateFlags flags;
+ VkBool32 logicOpEnable;
+ VkLogicOp logicOp;
+ uint32_t attachmentCount;
+ const VkPipelineColorBlendAttachmentState* pAttachments;
+ float blendConstants[4];
+} VkPipelineColorBlendStateCreateInfo;
+
+typedef struct VkPipelineDynamicStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineDynamicStateCreateFlags flags;
+ uint32_t dynamicStateCount;
+ const VkDynamicState* pDynamicStates;
+} VkPipelineDynamicStateCreateInfo;
+
+typedef struct VkGraphicsPipelineCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineCreateFlags flags;
+ uint32_t stageCount;
+ const VkPipelineShaderStageCreateInfo* pStages;
+ const VkPipelineVertexInputStateCreateInfo* pVertexInputState;
+ const VkPipelineInputAssemblyStateCreateInfo* pInputAssemblyState;
+ const VkPipelineTessellationStateCreateInfo* pTessellationState;
+ const VkPipelineViewportStateCreateInfo* pViewportState;
+ const VkPipelineRasterizationStateCreateInfo* pRasterizationState;
+ const VkPipelineMultisampleStateCreateInfo* pMultisampleState;
+ const VkPipelineDepthStencilStateCreateInfo* pDepthStencilState;
+ const VkPipelineColorBlendStateCreateInfo* pColorBlendState;
+ const VkPipelineDynamicStateCreateInfo* pDynamicState;
+ VkPipelineLayout layout;
+ VkRenderPass renderPass;
+ uint32_t subpass;
+ VkPipeline basePipelineHandle;
+ int32_t basePipelineIndex;
+} VkGraphicsPipelineCreateInfo;
+
+typedef struct VkComputePipelineCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineCreateFlags flags;
+ VkPipelineShaderStageCreateInfo stage;
+ VkPipelineLayout layout;
+ VkPipeline basePipelineHandle;
+ int32_t basePipelineIndex;
+} VkComputePipelineCreateInfo;
+
+typedef struct VkPushConstantRange {
+ VkShaderStageFlags stageFlags;
+ uint32_t offset;
+ uint32_t size;
+} VkPushConstantRange;
+
+typedef struct VkPipelineLayoutCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineLayoutCreateFlags flags;
+ uint32_t setLayoutCount;
+ const VkDescriptorSetLayout* pSetLayouts;
+ uint32_t pushConstantRangeCount;
+ const VkPushConstantRange* pPushConstantRanges;
+} VkPipelineLayoutCreateInfo;
+
+typedef struct VkSamplerCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkSamplerCreateFlags flags;
+ VkFilter magFilter;
+ VkFilter minFilter;
+ VkSamplerMipmapMode mipmapMode;
+ VkSamplerAddressMode addressModeU;
+ VkSamplerAddressMode addressModeV;
+ VkSamplerAddressMode addressModeW;
+ float mipLodBias;
+ VkBool32 anisotropyEnable;
+ float maxAnisotropy;
+ VkBool32 compareEnable;
+ VkCompareOp compareOp;
+ float minLod;
+ float maxLod;
+ VkBorderColor borderColor;
+ VkBool32 unnormalizedCoordinates;
+} VkSamplerCreateInfo;
+
+typedef struct VkDescriptorSetLayoutBinding {
+ uint32_t binding;
+ VkDescriptorType descriptorType;
+ uint32_t descriptorCount;
+ VkShaderStageFlags stageFlags;
+ const VkSampler* pImmutableSamplers;
+} VkDescriptorSetLayoutBinding;
+
+typedef struct VkDescriptorSetLayoutCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkDescriptorSetLayoutCreateFlags flags;
+ uint32_t bindingCount;
+ const VkDescriptorSetLayoutBinding* pBindings;
+} VkDescriptorSetLayoutCreateInfo;
+
+typedef struct VkDescriptorPoolSize {
+ VkDescriptorType type;
+ uint32_t descriptorCount;
+} VkDescriptorPoolSize;
+
+typedef struct VkDescriptorPoolCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkDescriptorPoolCreateFlags flags;
+ uint32_t maxSets;
+ uint32_t poolSizeCount;
+ const VkDescriptorPoolSize* pPoolSizes;
+} VkDescriptorPoolCreateInfo;
+
+typedef struct VkDescriptorSetAllocateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkDescriptorPool descriptorPool;
+ uint32_t descriptorSetCount;
+ const VkDescriptorSetLayout* pSetLayouts;
+} VkDescriptorSetAllocateInfo;
+
+typedef struct VkDescriptorImageInfo {
+ VkSampler sampler;
+ VkImageView imageView;
+ VkImageLayout imageLayout;
+} VkDescriptorImageInfo;
+
+typedef struct VkDescriptorBufferInfo {
+ VkBuffer buffer;
+ VkDeviceSize offset;
+ VkDeviceSize range;
+} VkDescriptorBufferInfo;
+
+typedef struct VkWriteDescriptorSet {
+ VkStructureType sType;
+ const void* pNext;
+ VkDescriptorSet dstSet;
+ uint32_t dstBinding;
+ uint32_t dstArrayElement;
+ uint32_t descriptorCount;
+ VkDescriptorType descriptorType;
+ const VkDescriptorImageInfo* pImageInfo;
+ const VkDescriptorBufferInfo* pBufferInfo;
+ const VkBufferView* pTexelBufferView;
+} VkWriteDescriptorSet;
+
+typedef struct VkCopyDescriptorSet {
+ VkStructureType sType;
+ const void* pNext;
+ VkDescriptorSet srcSet;
+ uint32_t srcBinding;
+ uint32_t srcArrayElement;
+ VkDescriptorSet dstSet;
+ uint32_t dstBinding;
+ uint32_t dstArrayElement;
+ uint32_t descriptorCount;
+} VkCopyDescriptorSet;
+
+typedef struct VkFramebufferCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkFramebufferCreateFlags flags;
+ VkRenderPass renderPass;
+ uint32_t attachmentCount;
+ const VkImageView* pAttachments;
+ uint32_t width;
+ uint32_t height;
+ uint32_t layers;
+} VkFramebufferCreateInfo;
+
+typedef struct VkAttachmentDescription {
+ VkAttachmentDescriptionFlags flags;
+ VkFormat format;
+ VkSampleCountFlagBits samples;
+ VkAttachmentLoadOp loadOp;
+ VkAttachmentStoreOp storeOp;
+ VkAttachmentLoadOp stencilLoadOp;
+ VkAttachmentStoreOp stencilStoreOp;
+ VkImageLayout initialLayout;
+ VkImageLayout finalLayout;
+} VkAttachmentDescription;
+
+typedef struct VkAttachmentReference {
+ uint32_t attachment;
+ VkImageLayout layout;
+} VkAttachmentReference;
+
+typedef struct VkSubpassDescription {
+ VkSubpassDescriptionFlags flags;
+ VkPipelineBindPoint pipelineBindPoint;
+ uint32_t inputAttachmentCount;
+ const VkAttachmentReference* pInputAttachments;
+ uint32_t colorAttachmentCount;
+ const VkAttachmentReference* pColorAttachments;
+ const VkAttachmentReference* pResolveAttachments;
+ const VkAttachmentReference* pDepthStencilAttachment;
+ uint32_t preserveAttachmentCount;
+ const uint32_t* pPreserveAttachments;
+} VkSubpassDescription;
+
+typedef struct VkSubpassDependency {
+ uint32_t srcSubpass;
+ uint32_t dstSubpass;
+ VkPipelineStageFlags srcStageMask;
+ VkPipelineStageFlags dstStageMask;
+ VkAccessFlags srcAccessMask;
+ VkAccessFlags dstAccessMask;
+ VkDependencyFlags dependencyFlags;
+} VkSubpassDependency;
+
+typedef struct VkRenderPassCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkRenderPassCreateFlags flags;
+ uint32_t attachmentCount;
+ const VkAttachmentDescription* pAttachments;
+ uint32_t subpassCount;
+ const VkSubpassDescription* pSubpasses;
+ uint32_t dependencyCount;
+ const VkSubpassDependency* pDependencies;
+} VkRenderPassCreateInfo;
+
+typedef struct VkCommandPoolCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkCommandPoolCreateFlags flags;
+ uint32_t queueFamilyIndex;
+} VkCommandPoolCreateInfo;
+
+typedef struct VkCommandBufferAllocateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkCommandPool commandPool;
+ VkCommandBufferLevel level;
+ uint32_t commandBufferCount;
+} VkCommandBufferAllocateInfo;
+
+typedef struct VkCommandBufferInheritanceInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkRenderPass renderPass;
+ uint32_t subpass;
+ VkFramebuffer framebuffer;
+ VkBool32 occlusionQueryEnable;
+ VkQueryControlFlags queryFlags;
+ VkQueryPipelineStatisticFlags pipelineStatistics;
+} VkCommandBufferInheritanceInfo;
+
+typedef struct VkCommandBufferBeginInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkCommandBufferUsageFlags flags;
+ const VkCommandBufferInheritanceInfo* pInheritanceInfo;
+} VkCommandBufferBeginInfo;
+
+typedef struct VkBufferCopy {
+ VkDeviceSize srcOffset;
+ VkDeviceSize dstOffset;
+ VkDeviceSize size;
+} VkBufferCopy;
+
+typedef struct VkImageSubresourceLayers {
+ VkImageAspectFlags aspectMask;
+ uint32_t mipLevel;
+ uint32_t baseArrayLayer;
+ uint32_t layerCount;
+} VkImageSubresourceLayers;
+
+typedef struct VkImageCopy {
+ VkImageSubresourceLayers srcSubresource;
+ VkOffset3D srcOffset;
+ VkImageSubresourceLayers dstSubresource;
+ VkOffset3D dstOffset;
+ VkExtent3D extent;
+} VkImageCopy;
+
+typedef struct VkImageBlit {
+ VkImageSubresourceLayers srcSubresource;
+ VkOffset3D srcOffsets[2];
+ VkImageSubresourceLayers dstSubresource;
+ VkOffset3D dstOffsets[2];
+} VkImageBlit;
+
+typedef struct VkBufferImageCopy {
+ VkDeviceSize bufferOffset;
+ uint32_t bufferRowLength;
+ uint32_t bufferImageHeight;
+ VkImageSubresourceLayers imageSubresource;
+ VkOffset3D imageOffset;
+ VkExtent3D imageExtent;
+} VkBufferImageCopy;
+
+typedef union VkClearColorValue {
+ float float32[4];
+ int32_t int32[4];
+ uint32_t uint32[4];
+} VkClearColorValue;
+
+typedef struct VkClearDepthStencilValue {
+ float depth;
+ uint32_t stencil;
+} VkClearDepthStencilValue;
+
+typedef union VkClearValue {
+ VkClearColorValue color;
+ VkClearDepthStencilValue depthStencil;
+} VkClearValue;
+
+typedef struct VkClearAttachment {
+ VkImageAspectFlags aspectMask;
+ uint32_t colorAttachment;
+ VkClearValue clearValue;
+} VkClearAttachment;
+
+typedef struct VkClearRect {
+ VkRect2D rect;
+ uint32_t baseArrayLayer;
+ uint32_t layerCount;
+} VkClearRect;
+
+typedef struct VkImageResolve {
+ VkImageSubresourceLayers srcSubresource;
+ VkOffset3D srcOffset;
+ VkImageSubresourceLayers dstSubresource;
+ VkOffset3D dstOffset;
+ VkExtent3D extent;
+} VkImageResolve;
+
+typedef struct VkMemoryBarrier {
+ VkStructureType sType;
+ const void* pNext;
+ VkAccessFlags srcAccessMask;
+ VkAccessFlags dstAccessMask;
+} VkMemoryBarrier;
+
+typedef struct VkBufferMemoryBarrier {
+ VkStructureType sType;
+ const void* pNext;
+ VkAccessFlags srcAccessMask;
+ VkAccessFlags dstAccessMask;
+ uint32_t srcQueueFamilyIndex;
+ uint32_t dstQueueFamilyIndex;
+ VkBuffer buffer;
+ VkDeviceSize offset;
+ VkDeviceSize size;
+} VkBufferMemoryBarrier;
+
+typedef struct VkImageMemoryBarrier {
+ VkStructureType sType;
+ const void* pNext;
+ VkAccessFlags srcAccessMask;
+ VkAccessFlags dstAccessMask;
+ VkImageLayout oldLayout;
+ VkImageLayout newLayout;
+ uint32_t srcQueueFamilyIndex;
+ uint32_t dstQueueFamilyIndex;
+ VkImage image;
+ VkImageSubresourceRange subresourceRange;
+} VkImageMemoryBarrier;
+
+typedef struct VkRenderPassBeginInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkRenderPass renderPass;
+ VkFramebuffer framebuffer;
+ VkRect2D renderArea;
+ uint32_t clearValueCount;
+ const VkClearValue* pClearValues;
+} VkRenderPassBeginInfo;
+
+typedef struct VkDispatchIndirectCommand {
+ uint32_t x;
+ uint32_t y;
+ uint32_t z;
+} VkDispatchIndirectCommand;
+
+typedef struct VkDrawIndexedIndirectCommand {
+ uint32_t indexCount;
+ uint32_t instanceCount;
+ uint32_t firstIndex;
+ int32_t vertexOffset;
+ uint32_t firstInstance;
+} VkDrawIndexedIndirectCommand;
+
+typedef struct VkDrawIndirectCommand {
+ uint32_t vertexCount;
+ uint32_t instanceCount;
+ uint32_t firstVertex;
+ uint32_t firstInstance;
+} VkDrawIndirectCommand;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateInstance)(const VkInstanceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkInstance* pInstance);
+typedef void (VKAPI_PTR *PFN_vkDestroyInstance)(VkInstance instance, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDevices)(VkInstance instance, uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures* pFeatures);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties* pFormatProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkImageFormatProperties* pImageFormatProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties* pProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties* pQueueFamilyProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties* pMemoryProperties);
+typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vkGetInstanceProcAddr)(VkInstance instance, const char* pName);
+typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vkGetDeviceProcAddr)(VkDevice device, const char* pName);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDevice)(VkPhysicalDevice physicalDevice, const VkDeviceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDevice* pDevice);
+typedef void (VKAPI_PTR *PFN_vkDestroyDevice)(VkDevice device, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceExtensionProperties)(const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkEnumerateDeviceExtensionProperties)(VkPhysicalDevice physicalDevice, const char* pLayerName, uint32_t* pPropertyCount, VkExtensionProperties* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceLayerProperties)(uint32_t* pPropertyCount, VkLayerProperties* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkEnumerateDeviceLayerProperties)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkLayerProperties* pProperties);
+typedef void (VKAPI_PTR *PFN_vkGetDeviceQueue)(VkDevice device, uint32_t queueFamilyIndex, uint32_t queueIndex, VkQueue* pQueue);
+typedef VkResult (VKAPI_PTR *PFN_vkQueueSubmit)(VkQueue queue, uint32_t submitCount, const VkSubmitInfo* pSubmits, VkFence fence);
+typedef VkResult (VKAPI_PTR *PFN_vkQueueWaitIdle)(VkQueue queue);
+typedef VkResult (VKAPI_PTR *PFN_vkDeviceWaitIdle)(VkDevice device);
+typedef VkResult (VKAPI_PTR *PFN_vkAllocateMemory)(VkDevice device, const VkMemoryAllocateInfo* pAllocateInfo, const VkAllocationCallbacks* pAllocator, VkDeviceMemory* pMemory);
+typedef void (VKAPI_PTR *PFN_vkFreeMemory)(VkDevice device, VkDeviceMemory memory, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkMapMemory)(VkDevice device, VkDeviceMemory memory, VkDeviceSize offset, VkDeviceSize size, VkMemoryMapFlags flags, void** ppData);
+typedef void (VKAPI_PTR *PFN_vkUnmapMemory)(VkDevice device, VkDeviceMemory memory);
+typedef VkResult (VKAPI_PTR *PFN_vkFlushMappedMemoryRanges)(VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges);
+typedef VkResult (VKAPI_PTR *PFN_vkInvalidateMappedMemoryRanges)(VkDevice device, uint32_t memoryRangeCount, const VkMappedMemoryRange* pMemoryRanges);
+typedef void (VKAPI_PTR *PFN_vkGetDeviceMemoryCommitment)(VkDevice device, VkDeviceMemory memory, VkDeviceSize* pCommittedMemoryInBytes);
+typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory)(VkDevice device, VkBuffer buffer, VkDeviceMemory memory, VkDeviceSize memoryOffset);
+typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory)(VkDevice device, VkImage image, VkDeviceMemory memory, VkDeviceSize memoryOffset);
+typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements)(VkDevice device, VkBuffer buffer, VkMemoryRequirements* pMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements)(VkDevice device, VkImage image, VkMemoryRequirements* pMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements)(VkDevice device, VkImage image, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements* pSparseMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkSampleCountFlagBits samples, VkImageUsageFlags usage, VkImageTiling tiling, uint32_t* pPropertyCount, VkSparseImageFormatProperties* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkQueueBindSparse)(VkQueue queue, uint32_t bindInfoCount, const VkBindSparseInfo* pBindInfo, VkFence fence);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateFence)(VkDevice device, const VkFenceCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence);
+typedef void (VKAPI_PTR *PFN_vkDestroyFence)(VkDevice device, VkFence fence, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkResetFences)(VkDevice device, uint32_t fenceCount, const VkFence* pFences);
+typedef VkResult (VKAPI_PTR *PFN_vkGetFenceStatus)(VkDevice device, VkFence fence);
+typedef VkResult (VKAPI_PTR *PFN_vkWaitForFences)(VkDevice device, uint32_t fenceCount, const VkFence* pFences, VkBool32 waitAll, uint64_t timeout);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateSemaphore)(VkDevice device, const VkSemaphoreCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSemaphore* pSemaphore);
+typedef void (VKAPI_PTR *PFN_vkDestroySemaphore)(VkDevice device, VkSemaphore semaphore, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateEvent)(VkDevice device, const VkEventCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkEvent* pEvent);
+typedef void (VKAPI_PTR *PFN_vkDestroyEvent)(VkDevice device, VkEvent event, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkGetEventStatus)(VkDevice device, VkEvent event);
+typedef VkResult (VKAPI_PTR *PFN_vkSetEvent)(VkDevice device, VkEvent event);
+typedef VkResult (VKAPI_PTR *PFN_vkResetEvent)(VkDevice device, VkEvent event);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateQueryPool)(VkDevice device, const VkQueryPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkQueryPool* pQueryPool);
+typedef void (VKAPI_PTR *PFN_vkDestroyQueryPool)(VkDevice device, VkQueryPool queryPool, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkGetQueryPoolResults)(VkDevice device, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, size_t dataSize, void* pData, VkDeviceSize stride, VkQueryResultFlags flags);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateBuffer)(VkDevice device, const VkBufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBuffer* pBuffer);
+typedef void (VKAPI_PTR *PFN_vkDestroyBuffer)(VkDevice device, VkBuffer buffer, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateBufferView)(VkDevice device, const VkBufferViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBufferView* pView);
+typedef void (VKAPI_PTR *PFN_vkDestroyBufferView)(VkDevice device, VkBufferView bufferView, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateImage)(VkDevice device, const VkImageCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImage* pImage);
+typedef void (VKAPI_PTR *PFN_vkDestroyImage)(VkDevice device, VkImage image, const VkAllocationCallbacks* pAllocator);
+typedef void (VKAPI_PTR *PFN_vkGetImageSubresourceLayout)(VkDevice device, VkImage image, const VkImageSubresource* pSubresource, VkSubresourceLayout* pLayout);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateImageView)(VkDevice device, const VkImageViewCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkImageView* pView);
+typedef void (VKAPI_PTR *PFN_vkDestroyImageView)(VkDevice device, VkImageView imageView, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateShaderModule)(VkDevice device, const VkShaderModuleCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkShaderModule* pShaderModule);
+typedef void (VKAPI_PTR *PFN_vkDestroyShaderModule)(VkDevice device, VkShaderModule shaderModule, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreatePipelineCache)(VkDevice device, const VkPipelineCacheCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineCache* pPipelineCache);
+typedef void (VKAPI_PTR *PFN_vkDestroyPipelineCache)(VkDevice device, VkPipelineCache pipelineCache, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPipelineCacheData)(VkDevice device, VkPipelineCache pipelineCache, size_t* pDataSize, void* pData);
+typedef VkResult (VKAPI_PTR *PFN_vkMergePipelineCaches)(VkDevice device, VkPipelineCache dstCache, uint32_t srcCacheCount, const VkPipelineCache* pSrcCaches);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateGraphicsPipelines)(VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkGraphicsPipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateComputePipelines)(VkDevice device, VkPipelineCache pipelineCache, uint32_t createInfoCount, const VkComputePipelineCreateInfo* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkPipeline* pPipelines);
+typedef void (VKAPI_PTR *PFN_vkDestroyPipeline)(VkDevice device, VkPipeline pipeline, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreatePipelineLayout)(VkDevice device, const VkPipelineLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkPipelineLayout* pPipelineLayout);
+typedef void (VKAPI_PTR *PFN_vkDestroyPipelineLayout)(VkDevice device, VkPipelineLayout pipelineLayout, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateSampler)(VkDevice device, const VkSamplerCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSampler* pSampler);
+typedef void (VKAPI_PTR *PFN_vkDestroySampler)(VkDevice device, VkSampler sampler, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorSetLayout)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorSetLayout* pSetLayout);
+typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorSetLayout)(VkDevice device, VkDescriptorSetLayout descriptorSetLayout, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorPool)(VkDevice device, const VkDescriptorPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorPool* pDescriptorPool);
+typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorPool)(VkDevice device, VkDescriptorPool descriptorPool, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkResetDescriptorPool)(VkDevice device, VkDescriptorPool descriptorPool, VkDescriptorPoolResetFlags flags);
+typedef VkResult (VKAPI_PTR *PFN_vkAllocateDescriptorSets)(VkDevice device, const VkDescriptorSetAllocateInfo* pAllocateInfo, VkDescriptorSet* pDescriptorSets);
+typedef VkResult (VKAPI_PTR *PFN_vkFreeDescriptorSets)(VkDevice device, VkDescriptorPool descriptorPool, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets);
+typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSets)(VkDevice device, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites, uint32_t descriptorCopyCount, const VkCopyDescriptorSet* pDescriptorCopies);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateFramebuffer)(VkDevice device, const VkFramebufferCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkFramebuffer* pFramebuffer);
+typedef void (VKAPI_PTR *PFN_vkDestroyFramebuffer)(VkDevice device, VkFramebuffer framebuffer, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateRenderPass)(VkDevice device, const VkRenderPassCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkRenderPass* pRenderPass);
+typedef void (VKAPI_PTR *PFN_vkDestroyRenderPass)(VkDevice device, VkRenderPass renderPass, const VkAllocationCallbacks* pAllocator);
+typedef void (VKAPI_PTR *PFN_vkGetRenderAreaGranularity)(VkDevice device, VkRenderPass renderPass, VkExtent2D* pGranularity);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateCommandPool)(VkDevice device, const VkCommandPoolCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkCommandPool* pCommandPool);
+typedef void (VKAPI_PTR *PFN_vkDestroyCommandPool)(VkDevice device, VkCommandPool commandPool, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkResetCommandPool)(VkDevice device, VkCommandPool commandPool, VkCommandPoolResetFlags flags);
+typedef VkResult (VKAPI_PTR *PFN_vkAllocateCommandBuffers)(VkDevice device, const VkCommandBufferAllocateInfo* pAllocateInfo, VkCommandBuffer* pCommandBuffers);
+typedef void (VKAPI_PTR *PFN_vkFreeCommandBuffers)(VkDevice device, VkCommandPool commandPool, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers);
+typedef VkResult (VKAPI_PTR *PFN_vkBeginCommandBuffer)(VkCommandBuffer commandBuffer, const VkCommandBufferBeginInfo* pBeginInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkEndCommandBuffer)(VkCommandBuffer commandBuffer);
+typedef VkResult (VKAPI_PTR *PFN_vkResetCommandBuffer)(VkCommandBuffer commandBuffer, VkCommandBufferResetFlags flags);
+typedef void (VKAPI_PTR *PFN_vkCmdBindPipeline)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipeline pipeline);
+typedef void (VKAPI_PTR *PFN_vkCmdSetViewport)(VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewport* pViewports);
+typedef void (VKAPI_PTR *PFN_vkCmdSetScissor)(VkCommandBuffer commandBuffer, uint32_t firstScissor, uint32_t scissorCount, const VkRect2D* pScissors);
+typedef void (VKAPI_PTR *PFN_vkCmdSetLineWidth)(VkCommandBuffer commandBuffer, float lineWidth);
+typedef void (VKAPI_PTR *PFN_vkCmdSetDepthBias)(VkCommandBuffer commandBuffer, float depthBiasConstantFactor, float depthBiasClamp, float depthBiasSlopeFactor);
+typedef void (VKAPI_PTR *PFN_vkCmdSetBlendConstants)(VkCommandBuffer commandBuffer, const float blendConstants[4]);
+typedef void (VKAPI_PTR *PFN_vkCmdSetDepthBounds)(VkCommandBuffer commandBuffer, float minDepthBounds, float maxDepthBounds);
+typedef void (VKAPI_PTR *PFN_vkCmdSetStencilCompareMask)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t compareMask);
+typedef void (VKAPI_PTR *PFN_vkCmdSetStencilWriteMask)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t writeMask);
+typedef void (VKAPI_PTR *PFN_vkCmdSetStencilReference)(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t reference);
+typedef void (VKAPI_PTR *PFN_vkCmdBindDescriptorSets)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t firstSet, uint32_t descriptorSetCount, const VkDescriptorSet* pDescriptorSets, uint32_t dynamicOffsetCount, const uint32_t* pDynamicOffsets);
+typedef void (VKAPI_PTR *PFN_vkCmdBindIndexBuffer)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkIndexType indexType);
+typedef void (VKAPI_PTR *PFN_vkCmdBindVertexBuffers)(VkCommandBuffer commandBuffer, uint32_t firstBinding, uint32_t bindingCount, const VkBuffer* pBuffers, const VkDeviceSize* pOffsets);
+typedef void (VKAPI_PTR *PFN_vkCmdDraw)(VkCommandBuffer commandBuffer, uint32_t vertexCount, uint32_t instanceCount, uint32_t firstVertex, uint32_t firstInstance);
+typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexed)(VkCommandBuffer commandBuffer, uint32_t indexCount, uint32_t instanceCount, uint32_t firstIndex, int32_t vertexOffset, uint32_t firstInstance);
+typedef void (VKAPI_PTR *PFN_vkCmdDrawIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride);
+typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexedIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, uint32_t drawCount, uint32_t stride);
+typedef void (VKAPI_PTR *PFN_vkCmdDispatch)(VkCommandBuffer commandBuffer, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ);
+typedef void (VKAPI_PTR *PFN_vkCmdDispatchIndirect)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset);
+typedef void (VKAPI_PTR *PFN_vkCmdCopyBuffer)(VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferCopy* pRegions);
+typedef void (VKAPI_PTR *PFN_vkCmdCopyImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageCopy* pRegions);
+typedef void (VKAPI_PTR *PFN_vkCmdBlitImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageBlit* pRegions, VkFilter filter);
+typedef void (VKAPI_PTR *PFN_vkCmdCopyBufferToImage)(VkCommandBuffer commandBuffer, VkBuffer srcBuffer, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkBufferImageCopy* pRegions);
+typedef void (VKAPI_PTR *PFN_vkCmdCopyImageToBuffer)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkBuffer dstBuffer, uint32_t regionCount, const VkBufferImageCopy* pRegions);
+typedef void (VKAPI_PTR *PFN_vkCmdUpdateBuffer)(VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize dataSize, const void* pData);
+typedef void (VKAPI_PTR *PFN_vkCmdFillBuffer)(VkCommandBuffer commandBuffer, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize size, uint32_t data);
+typedef void (VKAPI_PTR *PFN_vkCmdClearColorImage)(VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearColorValue* pColor, uint32_t rangeCount, const VkImageSubresourceRange* pRanges);
+typedef void (VKAPI_PTR *PFN_vkCmdClearDepthStencilImage)(VkCommandBuffer commandBuffer, VkImage image, VkImageLayout imageLayout, const VkClearDepthStencilValue* pDepthStencil, uint32_t rangeCount, const VkImageSubresourceRange* pRanges);
+typedef void (VKAPI_PTR *PFN_vkCmdClearAttachments)(VkCommandBuffer commandBuffer, uint32_t attachmentCount, const VkClearAttachment* pAttachments, uint32_t rectCount, const VkClearRect* pRects);
+typedef void (VKAPI_PTR *PFN_vkCmdResolveImage)(VkCommandBuffer commandBuffer, VkImage srcImage, VkImageLayout srcImageLayout, VkImage dstImage, VkImageLayout dstImageLayout, uint32_t regionCount, const VkImageResolve* pRegions);
+typedef void (VKAPI_PTR *PFN_vkCmdSetEvent)(VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask);
+typedef void (VKAPI_PTR *PFN_vkCmdResetEvent)(VkCommandBuffer commandBuffer, VkEvent event, VkPipelineStageFlags stageMask);
+typedef void (VKAPI_PTR *PFN_vkCmdWaitEvents)(VkCommandBuffer commandBuffer, uint32_t eventCount, const VkEvent* pEvents, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers);
+typedef void (VKAPI_PTR *PFN_vkCmdPipelineBarrier)(VkCommandBuffer commandBuffer, VkPipelineStageFlags srcStageMask, VkPipelineStageFlags dstStageMask, VkDependencyFlags dependencyFlags, uint32_t memoryBarrierCount, const VkMemoryBarrier* pMemoryBarriers, uint32_t bufferMemoryBarrierCount, const VkBufferMemoryBarrier* pBufferMemoryBarriers, uint32_t imageMemoryBarrierCount, const VkImageMemoryBarrier* pImageMemoryBarriers);
+typedef void (VKAPI_PTR *PFN_vkCmdBeginQuery)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query, VkQueryControlFlags flags);
+typedef void (VKAPI_PTR *PFN_vkCmdEndQuery)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t query);
+typedef void (VKAPI_PTR *PFN_vkCmdResetQueryPool)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount);
+typedef void (VKAPI_PTR *PFN_vkCmdWriteTimestamp)(VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkQueryPool queryPool, uint32_t query);
+typedef void (VKAPI_PTR *PFN_vkCmdCopyQueryPoolResults)(VkCommandBuffer commandBuffer, VkQueryPool queryPool, uint32_t firstQuery, uint32_t queryCount, VkBuffer dstBuffer, VkDeviceSize dstOffset, VkDeviceSize stride, VkQueryResultFlags flags);
+typedef void (VKAPI_PTR *PFN_vkCmdPushConstants)(VkCommandBuffer commandBuffer, VkPipelineLayout layout, VkShaderStageFlags stageFlags, uint32_t offset, uint32_t size, const void* pValues);
+typedef void (VKAPI_PTR *PFN_vkCmdBeginRenderPass)(VkCommandBuffer commandBuffer, const VkRenderPassBeginInfo* pRenderPassBegin, VkSubpassContents contents);
+typedef void (VKAPI_PTR *PFN_vkCmdNextSubpass)(VkCommandBuffer commandBuffer, VkSubpassContents contents);
+typedef void (VKAPI_PTR *PFN_vkCmdEndRenderPass)(VkCommandBuffer commandBuffer);
+typedef void (VKAPI_PTR *PFN_vkCmdExecuteCommands)(VkCommandBuffer commandBuffer, uint32_t commandBufferCount, const VkCommandBuffer* pCommandBuffers);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateInstance(
+ const VkInstanceCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkInstance* pInstance);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyInstance(
+ VkInstance instance,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDevices(
+ VkInstance instance,
+ uint32_t* pPhysicalDeviceCount,
+ VkPhysicalDevice* pPhysicalDevices);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceFeatures* pFeatures);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties(
+ VkPhysicalDevice physicalDevice,
+ VkFormat format,
+ VkFormatProperties* pFormatProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties(
+ VkPhysicalDevice physicalDevice,
+ VkFormat format,
+ VkImageType type,
+ VkImageTiling tiling,
+ VkImageUsageFlags usage,
+ VkImageCreateFlags flags,
+ VkImageFormatProperties* pImageFormatProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceProperties* pProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties(
+ VkPhysicalDevice physicalDevice,
+ uint32_t* pQueueFamilyPropertyCount,
+ VkQueueFamilyProperties* pQueueFamilyProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceMemoryProperties* pMemoryProperties);
+
+VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vkGetInstanceProcAddr(
+ VkInstance instance,
+ const char* pName);
+
+VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vkGetDeviceProcAddr(
+ VkDevice device,
+ const char* pName);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDevice(
+ VkPhysicalDevice physicalDevice,
+ const VkDeviceCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDevice* pDevice);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDevice(
+ VkDevice device,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceExtensionProperties(
+ const char* pLayerName,
+ uint32_t* pPropertyCount,
+ VkExtensionProperties* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateDeviceExtensionProperties(
+ VkPhysicalDevice physicalDevice,
+ const char* pLayerName,
+ uint32_t* pPropertyCount,
+ VkExtensionProperties* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceLayerProperties(
+ uint32_t* pPropertyCount,
+ VkLayerProperties* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateDeviceLayerProperties(
+ VkPhysicalDevice physicalDevice,
+ uint32_t* pPropertyCount,
+ VkLayerProperties* pProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetDeviceQueue(
+ VkDevice device,
+ uint32_t queueFamilyIndex,
+ uint32_t queueIndex,
+ VkQueue* pQueue);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkQueueSubmit(
+ VkQueue queue,
+ uint32_t submitCount,
+ const VkSubmitInfo* pSubmits,
+ VkFence fence);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkQueueWaitIdle(
+ VkQueue queue);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkDeviceWaitIdle(
+ VkDevice device);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkAllocateMemory(
+ VkDevice device,
+ const VkMemoryAllocateInfo* pAllocateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDeviceMemory* pMemory);
+
+VKAPI_ATTR void VKAPI_CALL vkFreeMemory(
+ VkDevice device,
+ VkDeviceMemory memory,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkMapMemory(
+ VkDevice device,
+ VkDeviceMemory memory,
+ VkDeviceSize offset,
+ VkDeviceSize size,
+ VkMemoryMapFlags flags,
+ void** ppData);
+
+VKAPI_ATTR void VKAPI_CALL vkUnmapMemory(
+ VkDevice device,
+ VkDeviceMemory memory);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkFlushMappedMemoryRanges(
+ VkDevice device,
+ uint32_t memoryRangeCount,
+ const VkMappedMemoryRange* pMemoryRanges);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkInvalidateMappedMemoryRanges(
+ VkDevice device,
+ uint32_t memoryRangeCount,
+ const VkMappedMemoryRange* pMemoryRanges);
+
+VKAPI_ATTR void VKAPI_CALL vkGetDeviceMemoryCommitment(
+ VkDevice device,
+ VkDeviceMemory memory,
+ VkDeviceSize* pCommittedMemoryInBytes);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory(
+ VkDevice device,
+ VkBuffer buffer,
+ VkDeviceMemory memory,
+ VkDeviceSize memoryOffset);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory(
+ VkDevice device,
+ VkImage image,
+ VkDeviceMemory memory,
+ VkDeviceSize memoryOffset);
+
+VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements(
+ VkDevice device,
+ VkBuffer buffer,
+ VkMemoryRequirements* pMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements(
+ VkDevice device,
+ VkImage image,
+ VkMemoryRequirements* pMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements(
+ VkDevice device,
+ VkImage image,
+ uint32_t* pSparseMemoryRequirementCount,
+ VkSparseImageMemoryRequirements* pSparseMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties(
+ VkPhysicalDevice physicalDevice,
+ VkFormat format,
+ VkImageType type,
+ VkSampleCountFlagBits samples,
+ VkImageUsageFlags usage,
+ VkImageTiling tiling,
+ uint32_t* pPropertyCount,
+ VkSparseImageFormatProperties* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkQueueBindSparse(
+ VkQueue queue,
+ uint32_t bindInfoCount,
+ const VkBindSparseInfo* pBindInfo,
+ VkFence fence);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateFence(
+ VkDevice device,
+ const VkFenceCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkFence* pFence);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyFence(
+ VkDevice device,
+ VkFence fence,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkResetFences(
+ VkDevice device,
+ uint32_t fenceCount,
+ const VkFence* pFences);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetFenceStatus(
+ VkDevice device,
+ VkFence fence);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkWaitForFences(
+ VkDevice device,
+ uint32_t fenceCount,
+ const VkFence* pFences,
+ VkBool32 waitAll,
+ uint64_t timeout);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateSemaphore(
+ VkDevice device,
+ const VkSemaphoreCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSemaphore* pSemaphore);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroySemaphore(
+ VkDevice device,
+ VkSemaphore semaphore,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateEvent(
+ VkDevice device,
+ const VkEventCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkEvent* pEvent);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyEvent(
+ VkDevice device,
+ VkEvent event,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetEventStatus(
+ VkDevice device,
+ VkEvent event);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkSetEvent(
+ VkDevice device,
+ VkEvent event);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkResetEvent(
+ VkDevice device,
+ VkEvent event);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateQueryPool(
+ VkDevice device,
+ const VkQueryPoolCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkQueryPool* pQueryPool);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyQueryPool(
+ VkDevice device,
+ VkQueryPool queryPool,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetQueryPoolResults(
+ VkDevice device,
+ VkQueryPool queryPool,
+ uint32_t firstQuery,
+ uint32_t queryCount,
+ size_t dataSize,
+ void* pData,
+ VkDeviceSize stride,
+ VkQueryResultFlags flags);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateBuffer(
+ VkDevice device,
+ const VkBufferCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkBuffer* pBuffer);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyBuffer(
+ VkDevice device,
+ VkBuffer buffer,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateBufferView(
+ VkDevice device,
+ const VkBufferViewCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkBufferView* pView);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyBufferView(
+ VkDevice device,
+ VkBufferView bufferView,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateImage(
+ VkDevice device,
+ const VkImageCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkImage* pImage);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyImage(
+ VkDevice device,
+ VkImage image,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR void VKAPI_CALL vkGetImageSubresourceLayout(
+ VkDevice device,
+ VkImage image,
+ const VkImageSubresource* pSubresource,
+ VkSubresourceLayout* pLayout);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateImageView(
+ VkDevice device,
+ const VkImageViewCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkImageView* pView);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyImageView(
+ VkDevice device,
+ VkImageView imageView,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateShaderModule(
+ VkDevice device,
+ const VkShaderModuleCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkShaderModule* pShaderModule);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyShaderModule(
+ VkDevice device,
+ VkShaderModule shaderModule,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreatePipelineCache(
+ VkDevice device,
+ const VkPipelineCacheCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkPipelineCache* pPipelineCache);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyPipelineCache(
+ VkDevice device,
+ VkPipelineCache pipelineCache,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPipelineCacheData(
+ VkDevice device,
+ VkPipelineCache pipelineCache,
+ size_t* pDataSize,
+ void* pData);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkMergePipelineCaches(
+ VkDevice device,
+ VkPipelineCache dstCache,
+ uint32_t srcCacheCount,
+ const VkPipelineCache* pSrcCaches);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateGraphicsPipelines(
+ VkDevice device,
+ VkPipelineCache pipelineCache,
+ uint32_t createInfoCount,
+ const VkGraphicsPipelineCreateInfo* pCreateInfos,
+ const VkAllocationCallbacks* pAllocator,
+ VkPipeline* pPipelines);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateComputePipelines(
+ VkDevice device,
+ VkPipelineCache pipelineCache,
+ uint32_t createInfoCount,
+ const VkComputePipelineCreateInfo* pCreateInfos,
+ const VkAllocationCallbacks* pAllocator,
+ VkPipeline* pPipelines);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyPipeline(
+ VkDevice device,
+ VkPipeline pipeline,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreatePipelineLayout(
+ VkDevice device,
+ const VkPipelineLayoutCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkPipelineLayout* pPipelineLayout);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyPipelineLayout(
+ VkDevice device,
+ VkPipelineLayout pipelineLayout,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateSampler(
+ VkDevice device,
+ const VkSamplerCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSampler* pSampler);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroySampler(
+ VkDevice device,
+ VkSampler sampler,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorSetLayout(
+ VkDevice device,
+ const VkDescriptorSetLayoutCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDescriptorSetLayout* pSetLayout);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorSetLayout(
+ VkDevice device,
+ VkDescriptorSetLayout descriptorSetLayout,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorPool(
+ VkDevice device,
+ const VkDescriptorPoolCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDescriptorPool* pDescriptorPool);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorPool(
+ VkDevice device,
+ VkDescriptorPool descriptorPool,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkResetDescriptorPool(
+ VkDevice device,
+ VkDescriptorPool descriptorPool,
+ VkDescriptorPoolResetFlags flags);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkAllocateDescriptorSets(
+ VkDevice device,
+ const VkDescriptorSetAllocateInfo* pAllocateInfo,
+ VkDescriptorSet* pDescriptorSets);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkFreeDescriptorSets(
+ VkDevice device,
+ VkDescriptorPool descriptorPool,
+ uint32_t descriptorSetCount,
+ const VkDescriptorSet* pDescriptorSets);
+
+VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSets(
+ VkDevice device,
+ uint32_t descriptorWriteCount,
+ const VkWriteDescriptorSet* pDescriptorWrites,
+ uint32_t descriptorCopyCount,
+ const VkCopyDescriptorSet* pDescriptorCopies);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateFramebuffer(
+ VkDevice device,
+ const VkFramebufferCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkFramebuffer* pFramebuffer);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyFramebuffer(
+ VkDevice device,
+ VkFramebuffer framebuffer,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateRenderPass(
+ VkDevice device,
+ const VkRenderPassCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkRenderPass* pRenderPass);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyRenderPass(
+ VkDevice device,
+ VkRenderPass renderPass,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR void VKAPI_CALL vkGetRenderAreaGranularity(
+ VkDevice device,
+ VkRenderPass renderPass,
+ VkExtent2D* pGranularity);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateCommandPool(
+ VkDevice device,
+ const VkCommandPoolCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkCommandPool* pCommandPool);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyCommandPool(
+ VkDevice device,
+ VkCommandPool commandPool,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkResetCommandPool(
+ VkDevice device,
+ VkCommandPool commandPool,
+ VkCommandPoolResetFlags flags);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkAllocateCommandBuffers(
+ VkDevice device,
+ const VkCommandBufferAllocateInfo* pAllocateInfo,
+ VkCommandBuffer* pCommandBuffers);
+
+VKAPI_ATTR void VKAPI_CALL vkFreeCommandBuffers(
+ VkDevice device,
+ VkCommandPool commandPool,
+ uint32_t commandBufferCount,
+ const VkCommandBuffer* pCommandBuffers);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkBeginCommandBuffer(
+ VkCommandBuffer commandBuffer,
+ const VkCommandBufferBeginInfo* pBeginInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEndCommandBuffer(
+ VkCommandBuffer commandBuffer);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkResetCommandBuffer(
+ VkCommandBuffer commandBuffer,
+ VkCommandBufferResetFlags flags);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBindPipeline(
+ VkCommandBuffer commandBuffer,
+ VkPipelineBindPoint pipelineBindPoint,
+ VkPipeline pipeline);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetViewport(
+ VkCommandBuffer commandBuffer,
+ uint32_t firstViewport,
+ uint32_t viewportCount,
+ const VkViewport* pViewports);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetScissor(
+ VkCommandBuffer commandBuffer,
+ uint32_t firstScissor,
+ uint32_t scissorCount,
+ const VkRect2D* pScissors);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetLineWidth(
+ VkCommandBuffer commandBuffer,
+ float lineWidth);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetDepthBias(
+ VkCommandBuffer commandBuffer,
+ float depthBiasConstantFactor,
+ float depthBiasClamp,
+ float depthBiasSlopeFactor);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetBlendConstants(
+ VkCommandBuffer commandBuffer,
+ const float blendConstants[4]);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetDepthBounds(
+ VkCommandBuffer commandBuffer,
+ float minDepthBounds,
+ float maxDepthBounds);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilCompareMask(
+ VkCommandBuffer commandBuffer,
+ VkStencilFaceFlags faceMask,
+ uint32_t compareMask);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilWriteMask(
+ VkCommandBuffer commandBuffer,
+ VkStencilFaceFlags faceMask,
+ uint32_t writeMask);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetStencilReference(
+ VkCommandBuffer commandBuffer,
+ VkStencilFaceFlags faceMask,
+ uint32_t reference);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBindDescriptorSets(
+ VkCommandBuffer commandBuffer,
+ VkPipelineBindPoint pipelineBindPoint,
+ VkPipelineLayout layout,
+ uint32_t firstSet,
+ uint32_t descriptorSetCount,
+ const VkDescriptorSet* pDescriptorSets,
+ uint32_t dynamicOffsetCount,
+ const uint32_t* pDynamicOffsets);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBindIndexBuffer(
+ VkCommandBuffer commandBuffer,
+ VkBuffer buffer,
+ VkDeviceSize offset,
+ VkIndexType indexType);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBindVertexBuffers(
+ VkCommandBuffer commandBuffer,
+ uint32_t firstBinding,
+ uint32_t bindingCount,
+ const VkBuffer* pBuffers,
+ const VkDeviceSize* pOffsets);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDraw(
+ VkCommandBuffer commandBuffer,
+ uint32_t vertexCount,
+ uint32_t instanceCount,
+ uint32_t firstVertex,
+ uint32_t firstInstance);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexed(
+ VkCommandBuffer commandBuffer,
+ uint32_t indexCount,
+ uint32_t instanceCount,
+ uint32_t firstIndex,
+ int32_t vertexOffset,
+ uint32_t firstInstance);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndirect(
+ VkCommandBuffer commandBuffer,
+ VkBuffer buffer,
+ VkDeviceSize offset,
+ uint32_t drawCount,
+ uint32_t stride);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexedIndirect(
+ VkCommandBuffer commandBuffer,
+ VkBuffer buffer,
+ VkDeviceSize offset,
+ uint32_t drawCount,
+ uint32_t stride);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDispatch(
+ VkCommandBuffer commandBuffer,
+ uint32_t groupCountX,
+ uint32_t groupCountY,
+ uint32_t groupCountZ);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDispatchIndirect(
+ VkCommandBuffer commandBuffer,
+ VkBuffer buffer,
+ VkDeviceSize offset);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdCopyBuffer(
+ VkCommandBuffer commandBuffer,
+ VkBuffer srcBuffer,
+ VkBuffer dstBuffer,
+ uint32_t regionCount,
+ const VkBufferCopy* pRegions);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdCopyImage(
+ VkCommandBuffer commandBuffer,
+ VkImage srcImage,
+ VkImageLayout srcImageLayout,
+ VkImage dstImage,
+ VkImageLayout dstImageLayout,
+ uint32_t regionCount,
+ const VkImageCopy* pRegions);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBlitImage(
+ VkCommandBuffer commandBuffer,
+ VkImage srcImage,
+ VkImageLayout srcImageLayout,
+ VkImage dstImage,
+ VkImageLayout dstImageLayout,
+ uint32_t regionCount,
+ const VkImageBlit* pRegions,
+ VkFilter filter);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdCopyBufferToImage(
+ VkCommandBuffer commandBuffer,
+ VkBuffer srcBuffer,
+ VkImage dstImage,
+ VkImageLayout dstImageLayout,
+ uint32_t regionCount,
+ const VkBufferImageCopy* pRegions);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdCopyImageToBuffer(
+ VkCommandBuffer commandBuffer,
+ VkImage srcImage,
+ VkImageLayout srcImageLayout,
+ VkBuffer dstBuffer,
+ uint32_t regionCount,
+ const VkBufferImageCopy* pRegions);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdUpdateBuffer(
+ VkCommandBuffer commandBuffer,
+ VkBuffer dstBuffer,
+ VkDeviceSize dstOffset,
+ VkDeviceSize dataSize,
+ const void* pData);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdFillBuffer(
+ VkCommandBuffer commandBuffer,
+ VkBuffer dstBuffer,
+ VkDeviceSize dstOffset,
+ VkDeviceSize size,
+ uint32_t data);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdClearColorImage(
+ VkCommandBuffer commandBuffer,
+ VkImage image,
+ VkImageLayout imageLayout,
+ const VkClearColorValue* pColor,
+ uint32_t rangeCount,
+ const VkImageSubresourceRange* pRanges);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdClearDepthStencilImage(
+ VkCommandBuffer commandBuffer,
+ VkImage image,
+ VkImageLayout imageLayout,
+ const VkClearDepthStencilValue* pDepthStencil,
+ uint32_t rangeCount,
+ const VkImageSubresourceRange* pRanges);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdClearAttachments(
+ VkCommandBuffer commandBuffer,
+ uint32_t attachmentCount,
+ const VkClearAttachment* pAttachments,
+ uint32_t rectCount,
+ const VkClearRect* pRects);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdResolveImage(
+ VkCommandBuffer commandBuffer,
+ VkImage srcImage,
+ VkImageLayout srcImageLayout,
+ VkImage dstImage,
+ VkImageLayout dstImageLayout,
+ uint32_t regionCount,
+ const VkImageResolve* pRegions);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetEvent(
+ VkCommandBuffer commandBuffer,
+ VkEvent event,
+ VkPipelineStageFlags stageMask);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdResetEvent(
+ VkCommandBuffer commandBuffer,
+ VkEvent event,
+ VkPipelineStageFlags stageMask);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdWaitEvents(
+ VkCommandBuffer commandBuffer,
+ uint32_t eventCount,
+ const VkEvent* pEvents,
+ VkPipelineStageFlags srcStageMask,
+ VkPipelineStageFlags dstStageMask,
+ uint32_t memoryBarrierCount,
+ const VkMemoryBarrier* pMemoryBarriers,
+ uint32_t bufferMemoryBarrierCount,
+ const VkBufferMemoryBarrier* pBufferMemoryBarriers,
+ uint32_t imageMemoryBarrierCount,
+ const VkImageMemoryBarrier* pImageMemoryBarriers);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdPipelineBarrier(
+ VkCommandBuffer commandBuffer,
+ VkPipelineStageFlags srcStageMask,
+ VkPipelineStageFlags dstStageMask,
+ VkDependencyFlags dependencyFlags,
+ uint32_t memoryBarrierCount,
+ const VkMemoryBarrier* pMemoryBarriers,
+ uint32_t bufferMemoryBarrierCount,
+ const VkBufferMemoryBarrier* pBufferMemoryBarriers,
+ uint32_t imageMemoryBarrierCount,
+ const VkImageMemoryBarrier* pImageMemoryBarriers);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBeginQuery(
+ VkCommandBuffer commandBuffer,
+ VkQueryPool queryPool,
+ uint32_t query,
+ VkQueryControlFlags flags);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdEndQuery(
+ VkCommandBuffer commandBuffer,
+ VkQueryPool queryPool,
+ uint32_t query);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdResetQueryPool(
+ VkCommandBuffer commandBuffer,
+ VkQueryPool queryPool,
+ uint32_t firstQuery,
+ uint32_t queryCount);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdWriteTimestamp(
+ VkCommandBuffer commandBuffer,
+ VkPipelineStageFlagBits pipelineStage,
+ VkQueryPool queryPool,
+ uint32_t query);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdCopyQueryPoolResults(
+ VkCommandBuffer commandBuffer,
+ VkQueryPool queryPool,
+ uint32_t firstQuery,
+ uint32_t queryCount,
+ VkBuffer dstBuffer,
+ VkDeviceSize dstOffset,
+ VkDeviceSize stride,
+ VkQueryResultFlags flags);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdPushConstants(
+ VkCommandBuffer commandBuffer,
+ VkPipelineLayout layout,
+ VkShaderStageFlags stageFlags,
+ uint32_t offset,
+ uint32_t size,
+ const void* pValues);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBeginRenderPass(
+ VkCommandBuffer commandBuffer,
+ const VkRenderPassBeginInfo* pRenderPassBegin,
+ VkSubpassContents contents);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdNextSubpass(
+ VkCommandBuffer commandBuffer,
+ VkSubpassContents contents);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdEndRenderPass(
+ VkCommandBuffer commandBuffer);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdExecuteCommands(
+ VkCommandBuffer commandBuffer,
+ uint32_t commandBufferCount,
+ const VkCommandBuffer* pCommandBuffers);
+#endif
+
+#define VK_VERSION_1_1 1
+// Vulkan 1.1 version number
+#define VK_API_VERSION_1_1 VK_MAKE_VERSION(1, 1, 0)// Patch version should always be set to 0
+
+
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSamplerYcbcrConversion)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDescriptorUpdateTemplate)
+
+#define VK_MAX_DEVICE_GROUP_SIZE 32
+#define VK_LUID_SIZE 8
+#define VK_QUEUE_FAMILY_EXTERNAL (~0U-1)
+
+
+typedef enum VkPointClippingBehavior {
+ VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES = 0,
+ VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY = 1,
+ VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES_KHR = VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES,
+ VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY_KHR = VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY,
+ VK_POINT_CLIPPING_BEHAVIOR_BEGIN_RANGE = VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES,
+ VK_POINT_CLIPPING_BEHAVIOR_END_RANGE = VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY,
+ VK_POINT_CLIPPING_BEHAVIOR_RANGE_SIZE = (VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY - VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES + 1),
+ VK_POINT_CLIPPING_BEHAVIOR_MAX_ENUM = 0x7FFFFFFF
+} VkPointClippingBehavior;
+
+typedef enum VkTessellationDomainOrigin {
+ VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT = 0,
+ VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT = 1,
+ VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT_KHR = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT,
+ VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT_KHR = VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT,
+ VK_TESSELLATION_DOMAIN_ORIGIN_BEGIN_RANGE = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT,
+ VK_TESSELLATION_DOMAIN_ORIGIN_END_RANGE = VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT,
+ VK_TESSELLATION_DOMAIN_ORIGIN_RANGE_SIZE = (VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT - VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT + 1),
+ VK_TESSELLATION_DOMAIN_ORIGIN_MAX_ENUM = 0x7FFFFFFF
+} VkTessellationDomainOrigin;
+
+typedef enum VkSamplerYcbcrModelConversion {
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY = 0,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY = 1,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709 = 2,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601 = 3,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020 = 4,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020_KHR = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_BEGIN_RANGE = VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_END_RANGE = VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020,
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_RANGE_SIZE = (VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020 - VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY + 1),
+ VK_SAMPLER_YCBCR_MODEL_CONVERSION_MAX_ENUM = 0x7FFFFFFF
+} VkSamplerYcbcrModelConversion;
+
+typedef enum VkSamplerYcbcrRange {
+ VK_SAMPLER_YCBCR_RANGE_ITU_FULL = 0,
+ VK_SAMPLER_YCBCR_RANGE_ITU_NARROW = 1,
+ VK_SAMPLER_YCBCR_RANGE_ITU_FULL_KHR = VK_SAMPLER_YCBCR_RANGE_ITU_FULL,
+ VK_SAMPLER_YCBCR_RANGE_ITU_NARROW_KHR = VK_SAMPLER_YCBCR_RANGE_ITU_NARROW,
+ VK_SAMPLER_YCBCR_RANGE_BEGIN_RANGE = VK_SAMPLER_YCBCR_RANGE_ITU_FULL,
+ VK_SAMPLER_YCBCR_RANGE_END_RANGE = VK_SAMPLER_YCBCR_RANGE_ITU_NARROW,
+ VK_SAMPLER_YCBCR_RANGE_RANGE_SIZE = (VK_SAMPLER_YCBCR_RANGE_ITU_NARROW - VK_SAMPLER_YCBCR_RANGE_ITU_FULL + 1),
+ VK_SAMPLER_YCBCR_RANGE_MAX_ENUM = 0x7FFFFFFF
+} VkSamplerYcbcrRange;
+
+typedef enum VkChromaLocation {
+ VK_CHROMA_LOCATION_COSITED_EVEN = 0,
+ VK_CHROMA_LOCATION_MIDPOINT = 1,
+ VK_CHROMA_LOCATION_COSITED_EVEN_KHR = VK_CHROMA_LOCATION_COSITED_EVEN,
+ VK_CHROMA_LOCATION_MIDPOINT_KHR = VK_CHROMA_LOCATION_MIDPOINT,
+ VK_CHROMA_LOCATION_BEGIN_RANGE = VK_CHROMA_LOCATION_COSITED_EVEN,
+ VK_CHROMA_LOCATION_END_RANGE = VK_CHROMA_LOCATION_MIDPOINT,
+ VK_CHROMA_LOCATION_RANGE_SIZE = (VK_CHROMA_LOCATION_MIDPOINT - VK_CHROMA_LOCATION_COSITED_EVEN + 1),
+ VK_CHROMA_LOCATION_MAX_ENUM = 0x7FFFFFFF
+} VkChromaLocation;
+
+typedef enum VkDescriptorUpdateTemplateType {
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET = 0,
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR = 1,
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET_KHR = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET,
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_BEGIN_RANGE = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET,
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_END_RANGE = VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET,
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_RANGE_SIZE = (VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET - VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET + 1),
+ VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_MAX_ENUM = 0x7FFFFFFF
+} VkDescriptorUpdateTemplateType;
+
+
+typedef enum VkSubgroupFeatureFlagBits {
+ VK_SUBGROUP_FEATURE_BASIC_BIT = 0x00000001,
+ VK_SUBGROUP_FEATURE_VOTE_BIT = 0x00000002,
+ VK_SUBGROUP_FEATURE_ARITHMETIC_BIT = 0x00000004,
+ VK_SUBGROUP_FEATURE_BALLOT_BIT = 0x00000008,
+ VK_SUBGROUP_FEATURE_SHUFFLE_BIT = 0x00000010,
+ VK_SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT = 0x00000020,
+ VK_SUBGROUP_FEATURE_CLUSTERED_BIT = 0x00000040,
+ VK_SUBGROUP_FEATURE_QUAD_BIT = 0x00000080,
+ VK_SUBGROUP_FEATURE_PARTITIONED_BIT_NV = 0x00000100,
+ VK_SUBGROUP_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkSubgroupFeatureFlagBits;
+typedef VkFlags VkSubgroupFeatureFlags;
+
+typedef enum VkPeerMemoryFeatureFlagBits {
+ VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT = 0x00000001,
+ VK_PEER_MEMORY_FEATURE_COPY_DST_BIT = 0x00000002,
+ VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT = 0x00000004,
+ VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT = 0x00000008,
+ VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT_KHR = VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT,
+ VK_PEER_MEMORY_FEATURE_COPY_DST_BIT_KHR = VK_PEER_MEMORY_FEATURE_COPY_DST_BIT,
+ VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT_KHR = VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT,
+ VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT_KHR = VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT,
+ VK_PEER_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkPeerMemoryFeatureFlagBits;
+typedef VkFlags VkPeerMemoryFeatureFlags;
+
+typedef enum VkMemoryAllocateFlagBits {
+ VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT = 0x00000001,
+ VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT_KHR = VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT,
+ VK_MEMORY_ALLOCATE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkMemoryAllocateFlagBits;
+typedef VkFlags VkMemoryAllocateFlags;
+typedef VkFlags VkCommandPoolTrimFlags;
+typedef VkFlags VkDescriptorUpdateTemplateCreateFlags;
+
+typedef enum VkExternalMemoryHandleTypeFlagBits {
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT = 0x00000001,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT = 0x00000002,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT = 0x00000004,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT = 0x00000008,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT = 0x00000010,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT = 0x00000020,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT = 0x00000040,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT = 0x00000200,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID = 0x00000400,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT = 0x00000080,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT = 0x00000100,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT_KHR = VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkExternalMemoryHandleTypeFlagBits;
+typedef VkFlags VkExternalMemoryHandleTypeFlags;
+
+typedef enum VkExternalMemoryFeatureFlagBits {
+ VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT = 0x00000001,
+ VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT = 0x00000002,
+ VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT = 0x00000004,
+ VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_KHR = VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT,
+ VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_KHR = VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT,
+ VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_KHR = VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT,
+ VK_EXTERNAL_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkExternalMemoryFeatureFlagBits;
+typedef VkFlags VkExternalMemoryFeatureFlags;
+
+typedef enum VkExternalFenceHandleTypeFlagBits {
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT = 0x00000001,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT = 0x00000002,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT = 0x00000004,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT = 0x00000008,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT_KHR = VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT,
+ VK_EXTERNAL_FENCE_HANDLE_TYPE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkExternalFenceHandleTypeFlagBits;
+typedef VkFlags VkExternalFenceHandleTypeFlags;
+
+typedef enum VkExternalFenceFeatureFlagBits {
+ VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT = 0x00000001,
+ VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT = 0x00000002,
+ VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT_KHR = VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT,
+ VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT_KHR = VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT,
+ VK_EXTERNAL_FENCE_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkExternalFenceFeatureFlagBits;
+typedef VkFlags VkExternalFenceFeatureFlags;
+
+typedef enum VkFenceImportFlagBits {
+ VK_FENCE_IMPORT_TEMPORARY_BIT = 0x00000001,
+ VK_FENCE_IMPORT_TEMPORARY_BIT_KHR = VK_FENCE_IMPORT_TEMPORARY_BIT,
+ VK_FENCE_IMPORT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkFenceImportFlagBits;
+typedef VkFlags VkFenceImportFlags;
+
+typedef enum VkSemaphoreImportFlagBits {
+ VK_SEMAPHORE_IMPORT_TEMPORARY_BIT = 0x00000001,
+ VK_SEMAPHORE_IMPORT_TEMPORARY_BIT_KHR = VK_SEMAPHORE_IMPORT_TEMPORARY_BIT,
+ VK_SEMAPHORE_IMPORT_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkSemaphoreImportFlagBits;
+typedef VkFlags VkSemaphoreImportFlags;
+
+typedef enum VkExternalSemaphoreHandleTypeFlagBits {
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT = 0x00000001,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT = 0x00000002,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT = 0x00000004,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT = 0x00000008,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT = 0x00000010,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT_KHR = VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT,
+ VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkExternalSemaphoreHandleTypeFlagBits;
+typedef VkFlags VkExternalSemaphoreHandleTypeFlags;
+
+typedef enum VkExternalSemaphoreFeatureFlagBits {
+ VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT = 0x00000001,
+ VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT = 0x00000002,
+ VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT_KHR = VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT,
+ VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT_KHR = VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT,
+ VK_EXTERNAL_SEMAPHORE_FEATURE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF
+} VkExternalSemaphoreFeatureFlagBits;
+typedef VkFlags VkExternalSemaphoreFeatureFlags;
+
+typedef struct VkPhysicalDeviceSubgroupProperties {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t subgroupSize;
+ VkShaderStageFlags supportedStages;
+ VkSubgroupFeatureFlags supportedOperations;
+ VkBool32 quadOperationsInAllStages;
+} VkPhysicalDeviceSubgroupProperties;
+
+typedef struct VkBindBufferMemoryInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkBuffer buffer;
+ VkDeviceMemory memory;
+ VkDeviceSize memoryOffset;
+} VkBindBufferMemoryInfo;
+
+typedef struct VkBindImageMemoryInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImage image;
+ VkDeviceMemory memory;
+ VkDeviceSize memoryOffset;
+} VkBindImageMemoryInfo;
+
+typedef struct VkPhysicalDevice16BitStorageFeatures {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 storageBuffer16BitAccess;
+ VkBool32 uniformAndStorageBuffer16BitAccess;
+ VkBool32 storagePushConstant16;
+ VkBool32 storageInputOutput16;
+} VkPhysicalDevice16BitStorageFeatures;
+
+typedef struct VkMemoryDedicatedRequirements {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 prefersDedicatedAllocation;
+ VkBool32 requiresDedicatedAllocation;
+} VkMemoryDedicatedRequirements;
+
+typedef struct VkMemoryDedicatedAllocateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImage image;
+ VkBuffer buffer;
+} VkMemoryDedicatedAllocateInfo;
+
+typedef struct VkMemoryAllocateFlagsInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkMemoryAllocateFlags flags;
+ uint32_t deviceMask;
+} VkMemoryAllocateFlagsInfo;
+
+typedef struct VkDeviceGroupRenderPassBeginInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t deviceMask;
+ uint32_t deviceRenderAreaCount;
+ const VkRect2D* pDeviceRenderAreas;
+} VkDeviceGroupRenderPassBeginInfo;
+
+typedef struct VkDeviceGroupCommandBufferBeginInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t deviceMask;
+} VkDeviceGroupCommandBufferBeginInfo;
+
+typedef struct VkDeviceGroupSubmitInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t waitSemaphoreCount;
+ const uint32_t* pWaitSemaphoreDeviceIndices;
+ uint32_t commandBufferCount;
+ const uint32_t* pCommandBufferDeviceMasks;
+ uint32_t signalSemaphoreCount;
+ const uint32_t* pSignalSemaphoreDeviceIndices;
+} VkDeviceGroupSubmitInfo;
+
+typedef struct VkDeviceGroupBindSparseInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t resourceDeviceIndex;
+ uint32_t memoryDeviceIndex;
+} VkDeviceGroupBindSparseInfo;
+
+typedef struct VkBindBufferMemoryDeviceGroupInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t deviceIndexCount;
+ const uint32_t* pDeviceIndices;
+} VkBindBufferMemoryDeviceGroupInfo;
+
+typedef struct VkBindImageMemoryDeviceGroupInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t deviceIndexCount;
+ const uint32_t* pDeviceIndices;
+ uint32_t splitInstanceBindRegionCount;
+ const VkRect2D* pSplitInstanceBindRegions;
+} VkBindImageMemoryDeviceGroupInfo;
+
+typedef struct VkPhysicalDeviceGroupProperties {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t physicalDeviceCount;
+ VkPhysicalDevice physicalDevices[VK_MAX_DEVICE_GROUP_SIZE];
+ VkBool32 subsetAllocation;
+} VkPhysicalDeviceGroupProperties;
+
+typedef struct VkDeviceGroupDeviceCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t physicalDeviceCount;
+ const VkPhysicalDevice* pPhysicalDevices;
+} VkDeviceGroupDeviceCreateInfo;
+
+typedef struct VkBufferMemoryRequirementsInfo2 {
+ VkStructureType sType;
+ const void* pNext;
+ VkBuffer buffer;
+} VkBufferMemoryRequirementsInfo2;
+
+typedef struct VkImageMemoryRequirementsInfo2 {
+ VkStructureType sType;
+ const void* pNext;
+ VkImage image;
+} VkImageMemoryRequirementsInfo2;
+
+typedef struct VkImageSparseMemoryRequirementsInfo2 {
+ VkStructureType sType;
+ const void* pNext;
+ VkImage image;
+} VkImageSparseMemoryRequirementsInfo2;
+
+typedef struct VkMemoryRequirements2 {
+ VkStructureType sType;
+ void* pNext;
+ VkMemoryRequirements memoryRequirements;
+} VkMemoryRequirements2;
+
+typedef struct VkSparseImageMemoryRequirements2 {
+ VkStructureType sType;
+ void* pNext;
+ VkSparseImageMemoryRequirements memoryRequirements;
+} VkSparseImageMemoryRequirements2;
+
+typedef struct VkPhysicalDeviceFeatures2 {
+ VkStructureType sType;
+ void* pNext;
+ VkPhysicalDeviceFeatures features;
+} VkPhysicalDeviceFeatures2;
+
+typedef struct VkPhysicalDeviceProperties2 {
+ VkStructureType sType;
+ void* pNext;
+ VkPhysicalDeviceProperties properties;
+} VkPhysicalDeviceProperties2;
+
+typedef struct VkFormatProperties2 {
+ VkStructureType sType;
+ void* pNext;
+ VkFormatProperties formatProperties;
+} VkFormatProperties2;
+
+typedef struct VkImageFormatProperties2 {
+ VkStructureType sType;
+ void* pNext;
+ VkImageFormatProperties imageFormatProperties;
+} VkImageFormatProperties2;
+
+typedef struct VkPhysicalDeviceImageFormatInfo2 {
+ VkStructureType sType;
+ const void* pNext;
+ VkFormat format;
+ VkImageType type;
+ VkImageTiling tiling;
+ VkImageUsageFlags usage;
+ VkImageCreateFlags flags;
+} VkPhysicalDeviceImageFormatInfo2;
+
+typedef struct VkQueueFamilyProperties2 {
+ VkStructureType sType;
+ void* pNext;
+ VkQueueFamilyProperties queueFamilyProperties;
+} VkQueueFamilyProperties2;
+
+typedef struct VkPhysicalDeviceMemoryProperties2 {
+ VkStructureType sType;
+ void* pNext;
+ VkPhysicalDeviceMemoryProperties memoryProperties;
+} VkPhysicalDeviceMemoryProperties2;
+
+typedef struct VkSparseImageFormatProperties2 {
+ VkStructureType sType;
+ void* pNext;
+ VkSparseImageFormatProperties properties;
+} VkSparseImageFormatProperties2;
+
+typedef struct VkPhysicalDeviceSparseImageFormatInfo2 {
+ VkStructureType sType;
+ const void* pNext;
+ VkFormat format;
+ VkImageType type;
+ VkSampleCountFlagBits samples;
+ VkImageUsageFlags usage;
+ VkImageTiling tiling;
+} VkPhysicalDeviceSparseImageFormatInfo2;
+
+typedef struct VkPhysicalDevicePointClippingProperties {
+ VkStructureType sType;
+ void* pNext;
+ VkPointClippingBehavior pointClippingBehavior;
+} VkPhysicalDevicePointClippingProperties;
+
+typedef struct VkInputAttachmentAspectReference {
+ uint32_t subpass;
+ uint32_t inputAttachmentIndex;
+ VkImageAspectFlags aspectMask;
+} VkInputAttachmentAspectReference;
+
+typedef struct VkRenderPassInputAttachmentAspectCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t aspectReferenceCount;
+ const VkInputAttachmentAspectReference* pAspectReferences;
+} VkRenderPassInputAttachmentAspectCreateInfo;
+
+typedef struct VkImageViewUsageCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImageUsageFlags usage;
+} VkImageViewUsageCreateInfo;
+
+typedef struct VkPipelineTessellationDomainOriginStateCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkTessellationDomainOrigin domainOrigin;
+} VkPipelineTessellationDomainOriginStateCreateInfo;
+
+typedef struct VkRenderPassMultiviewCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t subpassCount;
+ const uint32_t* pViewMasks;
+ uint32_t dependencyCount;
+ const int32_t* pViewOffsets;
+ uint32_t correlationMaskCount;
+ const uint32_t* pCorrelationMasks;
+} VkRenderPassMultiviewCreateInfo;
+
+typedef struct VkPhysicalDeviceMultiviewFeatures {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 multiview;
+ VkBool32 multiviewGeometryShader;
+ VkBool32 multiviewTessellationShader;
+} VkPhysicalDeviceMultiviewFeatures;
+
+typedef struct VkPhysicalDeviceMultiviewProperties {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxMultiviewViewCount;
+ uint32_t maxMultiviewInstanceIndex;
+} VkPhysicalDeviceMultiviewProperties;
+
+typedef struct VkPhysicalDeviceVariablePointerFeatures {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 variablePointersStorageBuffer;
+ VkBool32 variablePointers;
+} VkPhysicalDeviceVariablePointerFeatures;
+
+typedef struct VkPhysicalDeviceProtectedMemoryFeatures {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 protectedMemory;
+} VkPhysicalDeviceProtectedMemoryFeatures;
+
+typedef struct VkPhysicalDeviceProtectedMemoryProperties {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 protectedNoFault;
+} VkPhysicalDeviceProtectedMemoryProperties;
+
+typedef struct VkDeviceQueueInfo2 {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceQueueCreateFlags flags;
+ uint32_t queueFamilyIndex;
+ uint32_t queueIndex;
+} VkDeviceQueueInfo2;
+
+typedef struct VkProtectedSubmitInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 protectedSubmit;
+} VkProtectedSubmitInfo;
+
+typedef struct VkSamplerYcbcrConversionCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkFormat format;
+ VkSamplerYcbcrModelConversion ycbcrModel;
+ VkSamplerYcbcrRange ycbcrRange;
+ VkComponentMapping components;
+ VkChromaLocation xChromaOffset;
+ VkChromaLocation yChromaOffset;
+ VkFilter chromaFilter;
+ VkBool32 forceExplicitReconstruction;
+} VkSamplerYcbcrConversionCreateInfo;
+
+typedef struct VkSamplerYcbcrConversionInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkSamplerYcbcrConversion conversion;
+} VkSamplerYcbcrConversionInfo;
+
+typedef struct VkBindImagePlaneMemoryInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImageAspectFlagBits planeAspect;
+} VkBindImagePlaneMemoryInfo;
+
+typedef struct VkImagePlaneMemoryRequirementsInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkImageAspectFlagBits planeAspect;
+} VkImagePlaneMemoryRequirementsInfo;
+
+typedef struct VkPhysicalDeviceSamplerYcbcrConversionFeatures {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 samplerYcbcrConversion;
+} VkPhysicalDeviceSamplerYcbcrConversionFeatures;
+
+typedef struct VkSamplerYcbcrConversionImageFormatProperties {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t combinedImageSamplerDescriptorCount;
+} VkSamplerYcbcrConversionImageFormatProperties;
+
+typedef struct VkDescriptorUpdateTemplateEntry {
+ uint32_t dstBinding;
+ uint32_t dstArrayElement;
+ uint32_t descriptorCount;
+ VkDescriptorType descriptorType;
+ size_t offset;
+ size_t stride;
+} VkDescriptorUpdateTemplateEntry;
+
+typedef struct VkDescriptorUpdateTemplateCreateInfo {
+ VkStructureType sType;
+ void* pNext;
+ VkDescriptorUpdateTemplateCreateFlags flags;
+ uint32_t descriptorUpdateEntryCount;
+ const VkDescriptorUpdateTemplateEntry* pDescriptorUpdateEntries;
+ VkDescriptorUpdateTemplateType templateType;
+ VkDescriptorSetLayout descriptorSetLayout;
+ VkPipelineBindPoint pipelineBindPoint;
+ VkPipelineLayout pipelineLayout;
+ uint32_t set;
+} VkDescriptorUpdateTemplateCreateInfo;
+
+typedef struct VkExternalMemoryProperties {
+ VkExternalMemoryFeatureFlags externalMemoryFeatures;
+ VkExternalMemoryHandleTypeFlags exportFromImportedHandleTypes;
+ VkExternalMemoryHandleTypeFlags compatibleHandleTypes;
+} VkExternalMemoryProperties;
+
+typedef struct VkPhysicalDeviceExternalImageFormatInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+} VkPhysicalDeviceExternalImageFormatInfo;
+
+typedef struct VkExternalImageFormatProperties {
+ VkStructureType sType;
+ void* pNext;
+ VkExternalMemoryProperties externalMemoryProperties;
+} VkExternalImageFormatProperties;
+
+typedef struct VkPhysicalDeviceExternalBufferInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkBufferCreateFlags flags;
+ VkBufferUsageFlags usage;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+} VkPhysicalDeviceExternalBufferInfo;
+
+typedef struct VkExternalBufferProperties {
+ VkStructureType sType;
+ void* pNext;
+ VkExternalMemoryProperties externalMemoryProperties;
+} VkExternalBufferProperties;
+
+typedef struct VkPhysicalDeviceIDProperties {
+ VkStructureType sType;
+ void* pNext;
+ uint8_t deviceUUID[VK_UUID_SIZE];
+ uint8_t driverUUID[VK_UUID_SIZE];
+ uint8_t deviceLUID[VK_LUID_SIZE];
+ uint32_t deviceNodeMask;
+ VkBool32 deviceLUIDValid;
+} VkPhysicalDeviceIDProperties;
+
+typedef struct VkExternalMemoryImageCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlags handleTypes;
+} VkExternalMemoryImageCreateInfo;
+
+typedef struct VkExternalMemoryBufferCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlags handleTypes;
+} VkExternalMemoryBufferCreateInfo;
+
+typedef struct VkExportMemoryAllocateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlags handleTypes;
+} VkExportMemoryAllocateInfo;
+
+typedef struct VkPhysicalDeviceExternalFenceInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalFenceHandleTypeFlagBits handleType;
+} VkPhysicalDeviceExternalFenceInfo;
+
+typedef struct VkExternalFenceProperties {
+ VkStructureType sType;
+ void* pNext;
+ VkExternalFenceHandleTypeFlags exportFromImportedHandleTypes;
+ VkExternalFenceHandleTypeFlags compatibleHandleTypes;
+ VkExternalFenceFeatureFlags externalFenceFeatures;
+} VkExternalFenceProperties;
+
+typedef struct VkExportFenceCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalFenceHandleTypeFlags handleTypes;
+} VkExportFenceCreateInfo;
+
+typedef struct VkExportSemaphoreCreateInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalSemaphoreHandleTypeFlags handleTypes;
+} VkExportSemaphoreCreateInfo;
+
+typedef struct VkPhysicalDeviceExternalSemaphoreInfo {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalSemaphoreHandleTypeFlagBits handleType;
+} VkPhysicalDeviceExternalSemaphoreInfo;
+
+typedef struct VkExternalSemaphoreProperties {
+ VkStructureType sType;
+ void* pNext;
+ VkExternalSemaphoreHandleTypeFlags exportFromImportedHandleTypes;
+ VkExternalSemaphoreHandleTypeFlags compatibleHandleTypes;
+ VkExternalSemaphoreFeatureFlags externalSemaphoreFeatures;
+} VkExternalSemaphoreProperties;
+
+typedef struct VkPhysicalDeviceMaintenance3Properties {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxPerSetDescriptors;
+ VkDeviceSize maxMemoryAllocationSize;
+} VkPhysicalDeviceMaintenance3Properties;
+
+typedef struct VkDescriptorSetLayoutSupport {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 supported;
+} VkDescriptorSetLayoutSupport;
+
+typedef struct VkPhysicalDeviceShaderDrawParameterFeatures {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 shaderDrawParameters;
+} VkPhysicalDeviceShaderDrawParameterFeatures;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkEnumerateInstanceVersion)(uint32_t* pApiVersion);
+typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory2)(VkDevice device, uint32_t bindInfoCount, const VkBindBufferMemoryInfo* pBindInfos);
+typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory2)(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos);
+typedef void (VKAPI_PTR *PFN_vkGetDeviceGroupPeerMemoryFeatures)(VkDevice device, uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, VkPeerMemoryFeatureFlags* pPeerMemoryFeatures);
+typedef void (VKAPI_PTR *PFN_vkCmdSetDeviceMask)(VkCommandBuffer commandBuffer, uint32_t deviceMask);
+typedef void (VKAPI_PTR *PFN_vkCmdDispatchBase)(VkCommandBuffer commandBuffer, uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ);
+typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDeviceGroups)(VkInstance instance, uint32_t* pPhysicalDeviceGroupCount, VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties);
+typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements2)(VkDevice device, const VkImageMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements2)(VkDevice device, const VkBufferMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements2)(VkDevice device, const VkImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements2* pSparseMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures2)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2* pFeatures);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties2)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2* pProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties2)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2* pFormatProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties2)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, VkImageFormatProperties2* pImageFormatProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties2)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2* pQueueFamilyProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties2)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2* pMemoryProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties2)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2* pProperties);
+typedef void (VKAPI_PTR *PFN_vkTrimCommandPool)(VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlags flags);
+typedef void (VKAPI_PTR *PFN_vkGetDeviceQueue2)(VkDevice device, const VkDeviceQueueInfo2* pQueueInfo, VkQueue* pQueue);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateSamplerYcbcrConversion)(VkDevice device, const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSamplerYcbcrConversion* pYcbcrConversion);
+typedef void (VKAPI_PTR *PFN_vkDestroySamplerYcbcrConversion)(VkDevice device, VkSamplerYcbcrConversion ycbcrConversion, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorUpdateTemplate)(VkDevice device, const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate);
+typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorUpdateTemplate)(VkDevice device, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const VkAllocationCallbacks* pAllocator);
+typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSetWithTemplate)(VkDevice device, VkDescriptorSet descriptorSet, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalBufferProperties)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, VkExternalBufferProperties* pExternalBufferProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalFenceProperties)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, VkExternalFenceProperties* pExternalFenceProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalSemaphoreProperties)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, VkExternalSemaphoreProperties* pExternalSemaphoreProperties);
+typedef void (VKAPI_PTR *PFN_vkGetDescriptorSetLayoutSupport)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, VkDescriptorSetLayoutSupport* pSupport);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumerateInstanceVersion(
+ uint32_t* pApiVersion);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory2(
+ VkDevice device,
+ uint32_t bindInfoCount,
+ const VkBindBufferMemoryInfo* pBindInfos);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory2(
+ VkDevice device,
+ uint32_t bindInfoCount,
+ const VkBindImageMemoryInfo* pBindInfos);
+
+VKAPI_ATTR void VKAPI_CALL vkGetDeviceGroupPeerMemoryFeatures(
+ VkDevice device,
+ uint32_t heapIndex,
+ uint32_t localDeviceIndex,
+ uint32_t remoteDeviceIndex,
+ VkPeerMemoryFeatureFlags* pPeerMemoryFeatures);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetDeviceMask(
+ VkCommandBuffer commandBuffer,
+ uint32_t deviceMask);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDispatchBase(
+ VkCommandBuffer commandBuffer,
+ uint32_t baseGroupX,
+ uint32_t baseGroupY,
+ uint32_t baseGroupZ,
+ uint32_t groupCountX,
+ uint32_t groupCountY,
+ uint32_t groupCountZ);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDeviceGroups(
+ VkInstance instance,
+ uint32_t* pPhysicalDeviceGroupCount,
+ VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements2(
+ VkDevice device,
+ const VkImageMemoryRequirementsInfo2* pInfo,
+ VkMemoryRequirements2* pMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements2(
+ VkDevice device,
+ const VkBufferMemoryRequirementsInfo2* pInfo,
+ VkMemoryRequirements2* pMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements2(
+ VkDevice device,
+ const VkImageSparseMemoryRequirementsInfo2* pInfo,
+ uint32_t* pSparseMemoryRequirementCount,
+ VkSparseImageMemoryRequirements2* pSparseMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures2(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceFeatures2* pFeatures);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties2(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceProperties2* pProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties2(
+ VkPhysicalDevice physicalDevice,
+ VkFormat format,
+ VkFormatProperties2* pFormatProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties2(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo,
+ VkImageFormatProperties2* pImageFormatProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties2(
+ VkPhysicalDevice physicalDevice,
+ uint32_t* pQueueFamilyPropertyCount,
+ VkQueueFamilyProperties2* pQueueFamilyProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties2(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceMemoryProperties2* pMemoryProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties2(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo,
+ uint32_t* pPropertyCount,
+ VkSparseImageFormatProperties2* pProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkTrimCommandPool(
+ VkDevice device,
+ VkCommandPool commandPool,
+ VkCommandPoolTrimFlags flags);
+
+VKAPI_ATTR void VKAPI_CALL vkGetDeviceQueue2(
+ VkDevice device,
+ const VkDeviceQueueInfo2* pQueueInfo,
+ VkQueue* pQueue);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateSamplerYcbcrConversion(
+ VkDevice device,
+ const VkSamplerYcbcrConversionCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSamplerYcbcrConversion* pYcbcrConversion);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroySamplerYcbcrConversion(
+ VkDevice device,
+ VkSamplerYcbcrConversion ycbcrConversion,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorUpdateTemplate(
+ VkDevice device,
+ const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorUpdateTemplate(
+ VkDevice device,
+ VkDescriptorUpdateTemplate descriptorUpdateTemplate,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSetWithTemplate(
+ VkDevice device,
+ VkDescriptorSet descriptorSet,
+ VkDescriptorUpdateTemplate descriptorUpdateTemplate,
+ const void* pData);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalBufferProperties(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo,
+ VkExternalBufferProperties* pExternalBufferProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalFenceProperties(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo,
+ VkExternalFenceProperties* pExternalFenceProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalSemaphoreProperties(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo,
+ VkExternalSemaphoreProperties* pExternalSemaphoreProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetDescriptorSetLayoutSupport(
+ VkDevice device,
+ const VkDescriptorSetLayoutCreateInfo* pCreateInfo,
+ VkDescriptorSetLayoutSupport* pSupport);
+#endif
+
+#define VK_KHR_surface 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSurfaceKHR)
+
+#define VK_KHR_SURFACE_SPEC_VERSION 25
+#define VK_KHR_SURFACE_EXTENSION_NAME "VK_KHR_surface"
+#define VK_COLORSPACE_SRGB_NONLINEAR_KHR VK_COLOR_SPACE_SRGB_NONLINEAR_KHR
+
+
+typedef enum VkColorSpaceKHR {
+ VK_COLOR_SPACE_SRGB_NONLINEAR_KHR = 0,
+ VK_COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT = 1000104001,
+ VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT = 1000104002,
+ VK_COLOR_SPACE_DCI_P3_LINEAR_EXT = 1000104003,
+ VK_COLOR_SPACE_DCI_P3_NONLINEAR_EXT = 1000104004,
+ VK_COLOR_SPACE_BT709_LINEAR_EXT = 1000104005,
+ VK_COLOR_SPACE_BT709_NONLINEAR_EXT = 1000104006,
+ VK_COLOR_SPACE_BT2020_LINEAR_EXT = 1000104007,
+ VK_COLOR_SPACE_HDR10_ST2084_EXT = 1000104008,
+ VK_COLOR_SPACE_DOLBYVISION_EXT = 1000104009,
+ VK_COLOR_SPACE_HDR10_HLG_EXT = 1000104010,
+ VK_COLOR_SPACE_ADOBERGB_LINEAR_EXT = 1000104011,
+ VK_COLOR_SPACE_ADOBERGB_NONLINEAR_EXT = 1000104012,
+ VK_COLOR_SPACE_PASS_THROUGH_EXT = 1000104013,
+ VK_COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT = 1000104014,
+ VK_COLOR_SPACE_BEGIN_RANGE_KHR = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR,
+ VK_COLOR_SPACE_END_RANGE_KHR = VK_COLOR_SPACE_SRGB_NONLINEAR_KHR,
+ VK_COLOR_SPACE_RANGE_SIZE_KHR = (VK_COLOR_SPACE_SRGB_NONLINEAR_KHR - VK_COLOR_SPACE_SRGB_NONLINEAR_KHR + 1),
+ VK_COLOR_SPACE_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkColorSpaceKHR;
+
+typedef enum VkPresentModeKHR {
+ VK_PRESENT_MODE_IMMEDIATE_KHR = 0,
+ VK_PRESENT_MODE_MAILBOX_KHR = 1,
+ VK_PRESENT_MODE_FIFO_KHR = 2,
+ VK_PRESENT_MODE_FIFO_RELAXED_KHR = 3,
+ VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR = 1000111000,
+ VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR = 1000111001,
+ VK_PRESENT_MODE_BEGIN_RANGE_KHR = VK_PRESENT_MODE_IMMEDIATE_KHR,
+ VK_PRESENT_MODE_END_RANGE_KHR = VK_PRESENT_MODE_FIFO_RELAXED_KHR,
+ VK_PRESENT_MODE_RANGE_SIZE_KHR = (VK_PRESENT_MODE_FIFO_RELAXED_KHR - VK_PRESENT_MODE_IMMEDIATE_KHR + 1),
+ VK_PRESENT_MODE_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkPresentModeKHR;
+
+
+typedef enum VkSurfaceTransformFlagBitsKHR {
+ VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR = 0x00000001,
+ VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR = 0x00000002,
+ VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR = 0x00000004,
+ VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR = 0x00000008,
+ VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR = 0x00000010,
+ VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR = 0x00000020,
+ VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR = 0x00000040,
+ VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR = 0x00000080,
+ VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR = 0x00000100,
+ VK_SURFACE_TRANSFORM_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkSurfaceTransformFlagBitsKHR;
+typedef VkFlags VkSurfaceTransformFlagsKHR;
+
+typedef enum VkCompositeAlphaFlagBitsKHR {
+ VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR = 0x00000001,
+ VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR = 0x00000002,
+ VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR = 0x00000004,
+ VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR = 0x00000008,
+ VK_COMPOSITE_ALPHA_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkCompositeAlphaFlagBitsKHR;
+typedef VkFlags VkCompositeAlphaFlagsKHR;
+
+typedef struct VkSurfaceCapabilitiesKHR {
+ uint32_t minImageCount;
+ uint32_t maxImageCount;
+ VkExtent2D currentExtent;
+ VkExtent2D minImageExtent;
+ VkExtent2D maxImageExtent;
+ uint32_t maxImageArrayLayers;
+ VkSurfaceTransformFlagsKHR supportedTransforms;
+ VkSurfaceTransformFlagBitsKHR currentTransform;
+ VkCompositeAlphaFlagsKHR supportedCompositeAlpha;
+ VkImageUsageFlags supportedUsageFlags;
+} VkSurfaceCapabilitiesKHR;
+
+typedef struct VkSurfaceFormatKHR {
+ VkFormat format;
+ VkColorSpaceKHR colorSpace;
+} VkSurfaceFormatKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkDestroySurfaceKHR)(VkInstance instance, VkSurfaceKHR surface, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, VkSurfaceKHR surface, VkBool32* pSupported);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilitiesKHR* pSurfaceCapabilities);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceFormatsKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pSurfaceFormatCount, VkSurfaceFormatKHR* pSurfaceFormats);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfacePresentModesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pPresentModeCount, VkPresentModeKHR* pPresentModes);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkDestroySurfaceKHR(
+ VkInstance instance,
+ VkSurfaceKHR surface,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceSupportKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t queueFamilyIndex,
+ VkSurfaceKHR surface,
+ VkBool32* pSupported);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilitiesKHR(
+ VkPhysicalDevice physicalDevice,
+ VkSurfaceKHR surface,
+ VkSurfaceCapabilitiesKHR* pSurfaceCapabilities);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceFormatsKHR(
+ VkPhysicalDevice physicalDevice,
+ VkSurfaceKHR surface,
+ uint32_t* pSurfaceFormatCount,
+ VkSurfaceFormatKHR* pSurfaceFormats);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfacePresentModesKHR(
+ VkPhysicalDevice physicalDevice,
+ VkSurfaceKHR surface,
+ uint32_t* pPresentModeCount,
+ VkPresentModeKHR* pPresentModes);
+#endif
+
+#define VK_KHR_swapchain 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkSwapchainKHR)
+
+#define VK_KHR_SWAPCHAIN_SPEC_VERSION 70
+#define VK_KHR_SWAPCHAIN_EXTENSION_NAME "VK_KHR_swapchain"
+
+
+typedef enum VkSwapchainCreateFlagBitsKHR {
+ VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR = 0x00000001,
+ VK_SWAPCHAIN_CREATE_PROTECTED_BIT_KHR = 0x00000002,
+ VK_SWAPCHAIN_CREATE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkSwapchainCreateFlagBitsKHR;
+typedef VkFlags VkSwapchainCreateFlagsKHR;
+
+typedef enum VkDeviceGroupPresentModeFlagBitsKHR {
+ VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR = 0x00000001,
+ VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR = 0x00000002,
+ VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR = 0x00000004,
+ VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR = 0x00000008,
+ VK_DEVICE_GROUP_PRESENT_MODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkDeviceGroupPresentModeFlagBitsKHR;
+typedef VkFlags VkDeviceGroupPresentModeFlagsKHR;
+
+typedef struct VkSwapchainCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSwapchainCreateFlagsKHR flags;
+ VkSurfaceKHR surface;
+ uint32_t minImageCount;
+ VkFormat imageFormat;
+ VkColorSpaceKHR imageColorSpace;
+ VkExtent2D imageExtent;
+ uint32_t imageArrayLayers;
+ VkImageUsageFlags imageUsage;
+ VkSharingMode imageSharingMode;
+ uint32_t queueFamilyIndexCount;
+ const uint32_t* pQueueFamilyIndices;
+ VkSurfaceTransformFlagBitsKHR preTransform;
+ VkCompositeAlphaFlagBitsKHR compositeAlpha;
+ VkPresentModeKHR presentMode;
+ VkBool32 clipped;
+ VkSwapchainKHR oldSwapchain;
+} VkSwapchainCreateInfoKHR;
+
+typedef struct VkPresentInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t waitSemaphoreCount;
+ const VkSemaphore* pWaitSemaphores;
+ uint32_t swapchainCount;
+ const VkSwapchainKHR* pSwapchains;
+ const uint32_t* pImageIndices;
+ VkResult* pResults;
+} VkPresentInfoKHR;
+
+typedef struct VkImageSwapchainCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSwapchainKHR swapchain;
+} VkImageSwapchainCreateInfoKHR;
+
+typedef struct VkBindImageMemorySwapchainInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSwapchainKHR swapchain;
+ uint32_t imageIndex;
+} VkBindImageMemorySwapchainInfoKHR;
+
+typedef struct VkAcquireNextImageInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSwapchainKHR swapchain;
+ uint64_t timeout;
+ VkSemaphore semaphore;
+ VkFence fence;
+ uint32_t deviceMask;
+} VkAcquireNextImageInfoKHR;
+
+typedef struct VkDeviceGroupPresentCapabilitiesKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t presentMask[VK_MAX_DEVICE_GROUP_SIZE];
+ VkDeviceGroupPresentModeFlagsKHR modes;
+} VkDeviceGroupPresentCapabilitiesKHR;
+
+typedef struct VkDeviceGroupPresentInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t swapchainCount;
+ const uint32_t* pDeviceMasks;
+ VkDeviceGroupPresentModeFlagBitsKHR mode;
+} VkDeviceGroupPresentInfoKHR;
+
+typedef struct VkDeviceGroupSwapchainCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceGroupPresentModeFlagsKHR modes;
+} VkDeviceGroupSwapchainCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateSwapchainKHR)(VkDevice device, const VkSwapchainCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchain);
+typedef void (VKAPI_PTR *PFN_vkDestroySwapchainKHR)(VkDevice device, VkSwapchainKHR swapchain, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainImagesKHR)(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pSwapchainImageCount, VkImage* pSwapchainImages);
+typedef VkResult (VKAPI_PTR *PFN_vkAcquireNextImageKHR)(VkDevice device, VkSwapchainKHR swapchain, uint64_t timeout, VkSemaphore semaphore, VkFence fence, uint32_t* pImageIndex);
+typedef VkResult (VKAPI_PTR *PFN_vkQueuePresentKHR)(VkQueue queue, const VkPresentInfoKHR* pPresentInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkGetDeviceGroupPresentCapabilitiesKHR)(VkDevice device, VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities);
+typedef VkResult (VKAPI_PTR *PFN_vkGetDeviceGroupSurfacePresentModesKHR)(VkDevice device, VkSurfaceKHR surface, VkDeviceGroupPresentModeFlagsKHR* pModes);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDevicePresentRectanglesKHR)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, uint32_t* pRectCount, VkRect2D* pRects);
+typedef VkResult (VKAPI_PTR *PFN_vkAcquireNextImage2KHR)(VkDevice device, const VkAcquireNextImageInfoKHR* pAcquireInfo, uint32_t* pImageIndex);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateSwapchainKHR(
+ VkDevice device,
+ const VkSwapchainCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSwapchainKHR* pSwapchain);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroySwapchainKHR(
+ VkDevice device,
+ VkSwapchainKHR swapchain,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainImagesKHR(
+ VkDevice device,
+ VkSwapchainKHR swapchain,
+ uint32_t* pSwapchainImageCount,
+ VkImage* pSwapchainImages);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkAcquireNextImageKHR(
+ VkDevice device,
+ VkSwapchainKHR swapchain,
+ uint64_t timeout,
+ VkSemaphore semaphore,
+ VkFence fence,
+ uint32_t* pImageIndex);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkQueuePresentKHR(
+ VkQueue queue,
+ const VkPresentInfoKHR* pPresentInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetDeviceGroupPresentCapabilitiesKHR(
+ VkDevice device,
+ VkDeviceGroupPresentCapabilitiesKHR* pDeviceGroupPresentCapabilities);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetDeviceGroupSurfacePresentModesKHR(
+ VkDevice device,
+ VkSurfaceKHR surface,
+ VkDeviceGroupPresentModeFlagsKHR* pModes);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDevicePresentRectanglesKHR(
+ VkPhysicalDevice physicalDevice,
+ VkSurfaceKHR surface,
+ uint32_t* pRectCount,
+ VkRect2D* pRects);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkAcquireNextImage2KHR(
+ VkDevice device,
+ const VkAcquireNextImageInfoKHR* pAcquireInfo,
+ uint32_t* pImageIndex);
+#endif
+
+#define VK_KHR_display 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDisplayKHR)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDisplayModeKHR)
+
+#define VK_KHR_DISPLAY_SPEC_VERSION 21
+#define VK_KHR_DISPLAY_EXTENSION_NAME "VK_KHR_display"
+
+
+typedef enum VkDisplayPlaneAlphaFlagBitsKHR {
+ VK_DISPLAY_PLANE_ALPHA_OPAQUE_BIT_KHR = 0x00000001,
+ VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR = 0x00000002,
+ VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR = 0x00000004,
+ VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_PREMULTIPLIED_BIT_KHR = 0x00000008,
+ VK_DISPLAY_PLANE_ALPHA_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
+} VkDisplayPlaneAlphaFlagBitsKHR;
+typedef VkFlags VkDisplayPlaneAlphaFlagsKHR;
+typedef VkFlags VkDisplayModeCreateFlagsKHR;
+typedef VkFlags VkDisplaySurfaceCreateFlagsKHR;
+
+typedef struct VkDisplayPropertiesKHR {
+ VkDisplayKHR display;
+ const char* displayName;
+ VkExtent2D physicalDimensions;
+ VkExtent2D physicalResolution;
+ VkSurfaceTransformFlagsKHR supportedTransforms;
+ VkBool32 planeReorderPossible;
+ VkBool32 persistentContent;
+} VkDisplayPropertiesKHR;
+
+typedef struct VkDisplayModeParametersKHR {
+ VkExtent2D visibleRegion;
+ uint32_t refreshRate;
+} VkDisplayModeParametersKHR;
+
+typedef struct VkDisplayModePropertiesKHR {
+ VkDisplayModeKHR displayMode;
+ VkDisplayModeParametersKHR parameters;
+} VkDisplayModePropertiesKHR;
+
+typedef struct VkDisplayModeCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkDisplayModeCreateFlagsKHR flags;
+ VkDisplayModeParametersKHR parameters;
+} VkDisplayModeCreateInfoKHR;
+
+typedef struct VkDisplayPlaneCapabilitiesKHR {
+ VkDisplayPlaneAlphaFlagsKHR supportedAlpha;
+ VkOffset2D minSrcPosition;
+ VkOffset2D maxSrcPosition;
+ VkExtent2D minSrcExtent;
+ VkExtent2D maxSrcExtent;
+ VkOffset2D minDstPosition;
+ VkOffset2D maxDstPosition;
+ VkExtent2D minDstExtent;
+ VkExtent2D maxDstExtent;
+} VkDisplayPlaneCapabilitiesKHR;
+
+typedef struct VkDisplayPlanePropertiesKHR {
+ VkDisplayKHR currentDisplay;
+ uint32_t currentStackIndex;
+} VkDisplayPlanePropertiesKHR;
+
+typedef struct VkDisplaySurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkDisplaySurfaceCreateFlagsKHR flags;
+ VkDisplayModeKHR displayMode;
+ uint32_t planeIndex;
+ uint32_t planeStackIndex;
+ VkSurfaceTransformFlagBitsKHR transform;
+ float globalAlpha;
+ VkDisplayPlaneAlphaFlagBitsKHR alphaMode;
+ VkExtent2D imageExtent;
+} VkDisplaySurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPropertiesKHR* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR)(VkPhysicalDevice physicalDevice, uint32_t* pPropertyCount, VkDisplayPlanePropertiesKHR* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneSupportedDisplaysKHR)(VkPhysicalDevice physicalDevice, uint32_t planeIndex, uint32_t* pDisplayCount, VkDisplayKHR* pDisplays);
+typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayModePropertiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, uint32_t* pPropertyCount, VkDisplayModePropertiesKHR* pProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayModeKHR)(VkPhysicalDevice physicalDevice, VkDisplayKHR display, const VkDisplayModeCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDisplayModeKHR* pMode);
+typedef VkResult (VKAPI_PTR *PFN_vkGetDisplayPlaneCapabilitiesKHR)(VkPhysicalDevice physicalDevice, VkDisplayModeKHR mode, uint32_t planeIndex, VkDisplayPlaneCapabilitiesKHR* pCapabilities);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDisplayPlaneSurfaceKHR)(VkInstance instance, const VkDisplaySurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceDisplayPropertiesKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t* pPropertyCount,
+ VkDisplayPropertiesKHR* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceDisplayPlanePropertiesKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t* pPropertyCount,
+ VkDisplayPlanePropertiesKHR* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayPlaneSupportedDisplaysKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t planeIndex,
+ uint32_t* pDisplayCount,
+ VkDisplayKHR* pDisplays);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayModePropertiesKHR(
+ VkPhysicalDevice physicalDevice,
+ VkDisplayKHR display,
+ uint32_t* pPropertyCount,
+ VkDisplayModePropertiesKHR* pProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDisplayModeKHR(
+ VkPhysicalDevice physicalDevice,
+ VkDisplayKHR display,
+ const VkDisplayModeCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDisplayModeKHR* pMode);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetDisplayPlaneCapabilitiesKHR(
+ VkPhysicalDevice physicalDevice,
+ VkDisplayModeKHR mode,
+ uint32_t planeIndex,
+ VkDisplayPlaneCapabilitiesKHR* pCapabilities);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDisplayPlaneSurfaceKHR(
+ VkInstance instance,
+ const VkDisplaySurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+#endif
+
+#define VK_KHR_display_swapchain 1
+#define VK_KHR_DISPLAY_SWAPCHAIN_SPEC_VERSION 9
+#define VK_KHR_DISPLAY_SWAPCHAIN_EXTENSION_NAME "VK_KHR_display_swapchain"
+
+typedef struct VkDisplayPresentInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkRect2D srcRect;
+ VkRect2D dstRect;
+ VkBool32 persistent;
+} VkDisplayPresentInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateSharedSwapchainsKHR)(VkDevice device, uint32_t swapchainCount, const VkSwapchainCreateInfoKHR* pCreateInfos, const VkAllocationCallbacks* pAllocator, VkSwapchainKHR* pSwapchains);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateSharedSwapchainsKHR(
+ VkDevice device,
+ uint32_t swapchainCount,
+ const VkSwapchainCreateInfoKHR* pCreateInfos,
+ const VkAllocationCallbacks* pAllocator,
+ VkSwapchainKHR* pSwapchains);
+#endif
+
+#define VK_KHR_sampler_mirror_clamp_to_edge 1
+#define VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_SPEC_VERSION 1
+#define VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_EXTENSION_NAME "VK_KHR_sampler_mirror_clamp_to_edge"
+
+
+#define VK_KHR_multiview 1
+#define VK_KHR_MULTIVIEW_SPEC_VERSION 1
+#define VK_KHR_MULTIVIEW_EXTENSION_NAME "VK_KHR_multiview"
+
+typedef VkRenderPassMultiviewCreateInfo VkRenderPassMultiviewCreateInfoKHR;
+
+typedef VkPhysicalDeviceMultiviewFeatures VkPhysicalDeviceMultiviewFeaturesKHR;
+
+typedef VkPhysicalDeviceMultiviewProperties VkPhysicalDeviceMultiviewPropertiesKHR;
+
+
+
+#define VK_KHR_get_physical_device_properties2 1
+#define VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_SPEC_VERSION 1
+#define VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME "VK_KHR_get_physical_device_properties2"
+
+typedef VkPhysicalDeviceFeatures2 VkPhysicalDeviceFeatures2KHR;
+
+typedef VkPhysicalDeviceProperties2 VkPhysicalDeviceProperties2KHR;
+
+typedef VkFormatProperties2 VkFormatProperties2KHR;
+
+typedef VkImageFormatProperties2 VkImageFormatProperties2KHR;
+
+typedef VkPhysicalDeviceImageFormatInfo2 VkPhysicalDeviceImageFormatInfo2KHR;
+
+typedef VkQueueFamilyProperties2 VkQueueFamilyProperties2KHR;
+
+typedef VkPhysicalDeviceMemoryProperties2 VkPhysicalDeviceMemoryProperties2KHR;
+
+typedef VkSparseImageFormatProperties2 VkSparseImageFormatProperties2KHR;
+
+typedef VkPhysicalDeviceSparseImageFormatInfo2 VkPhysicalDeviceSparseImageFormatInfo2KHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFeatures2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceFeatures2* pFeatures);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceProperties2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceProperties2* pProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceFormatProperties2KHR)(VkPhysicalDevice physicalDevice, VkFormat format, VkFormatProperties2* pFormatProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceImageFormatProperties2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo, VkImageFormatProperties2* pImageFormatProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceQueueFamilyProperties2KHR)(VkPhysicalDevice physicalDevice, uint32_t* pQueueFamilyPropertyCount, VkQueueFamilyProperties2* pQueueFamilyProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMemoryProperties2KHR)(VkPhysicalDevice physicalDevice, VkPhysicalDeviceMemoryProperties2* pMemoryProperties);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceSparseImageFormatProperties2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo, uint32_t* pPropertyCount, VkSparseImageFormatProperties2* pProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFeatures2KHR(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceFeatures2* pFeatures);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceProperties2KHR(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceProperties2* pProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceFormatProperties2KHR(
+ VkPhysicalDevice physicalDevice,
+ VkFormat format,
+ VkFormatProperties2* pFormatProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceImageFormatProperties2KHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceImageFormatInfo2* pImageFormatInfo,
+ VkImageFormatProperties2* pImageFormatProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceQueueFamilyProperties2KHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t* pQueueFamilyPropertyCount,
+ VkQueueFamilyProperties2* pQueueFamilyProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMemoryProperties2KHR(
+ VkPhysicalDevice physicalDevice,
+ VkPhysicalDeviceMemoryProperties2* pMemoryProperties);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceSparseImageFormatProperties2KHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceSparseImageFormatInfo2* pFormatInfo,
+ uint32_t* pPropertyCount,
+ VkSparseImageFormatProperties2* pProperties);
+#endif
+
+#define VK_KHR_device_group 1
+#define VK_KHR_DEVICE_GROUP_SPEC_VERSION 3
+#define VK_KHR_DEVICE_GROUP_EXTENSION_NAME "VK_KHR_device_group"
+
+typedef VkPeerMemoryFeatureFlags VkPeerMemoryFeatureFlagsKHR;
+
+typedef VkPeerMemoryFeatureFlagBits VkPeerMemoryFeatureFlagBitsKHR;
+
+typedef VkMemoryAllocateFlags VkMemoryAllocateFlagsKHR;
+
+typedef VkMemoryAllocateFlagBits VkMemoryAllocateFlagBitsKHR;
+
+
+typedef VkMemoryAllocateFlagsInfo VkMemoryAllocateFlagsInfoKHR;
+
+typedef VkDeviceGroupRenderPassBeginInfo VkDeviceGroupRenderPassBeginInfoKHR;
+
+typedef VkDeviceGroupCommandBufferBeginInfo VkDeviceGroupCommandBufferBeginInfoKHR;
+
+typedef VkDeviceGroupSubmitInfo VkDeviceGroupSubmitInfoKHR;
+
+typedef VkDeviceGroupBindSparseInfo VkDeviceGroupBindSparseInfoKHR;
+
+typedef VkBindBufferMemoryDeviceGroupInfo VkBindBufferMemoryDeviceGroupInfoKHR;
+
+typedef VkBindImageMemoryDeviceGroupInfo VkBindImageMemoryDeviceGroupInfoKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetDeviceGroupPeerMemoryFeaturesKHR)(VkDevice device, uint32_t heapIndex, uint32_t localDeviceIndex, uint32_t remoteDeviceIndex, VkPeerMemoryFeatureFlags* pPeerMemoryFeatures);
+typedef void (VKAPI_PTR *PFN_vkCmdSetDeviceMaskKHR)(VkCommandBuffer commandBuffer, uint32_t deviceMask);
+typedef void (VKAPI_PTR *PFN_vkCmdDispatchBaseKHR)(VkCommandBuffer commandBuffer, uint32_t baseGroupX, uint32_t baseGroupY, uint32_t baseGroupZ, uint32_t groupCountX, uint32_t groupCountY, uint32_t groupCountZ);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetDeviceGroupPeerMemoryFeaturesKHR(
+ VkDevice device,
+ uint32_t heapIndex,
+ uint32_t localDeviceIndex,
+ uint32_t remoteDeviceIndex,
+ VkPeerMemoryFeatureFlags* pPeerMemoryFeatures);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdSetDeviceMaskKHR(
+ VkCommandBuffer commandBuffer,
+ uint32_t deviceMask);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDispatchBaseKHR(
+ VkCommandBuffer commandBuffer,
+ uint32_t baseGroupX,
+ uint32_t baseGroupY,
+ uint32_t baseGroupZ,
+ uint32_t groupCountX,
+ uint32_t groupCountY,
+ uint32_t groupCountZ);
+#endif
+
+#define VK_KHR_shader_draw_parameters 1
+#define VK_KHR_SHADER_DRAW_PARAMETERS_SPEC_VERSION 1
+#define VK_KHR_SHADER_DRAW_PARAMETERS_EXTENSION_NAME "VK_KHR_shader_draw_parameters"
+
+
+#define VK_KHR_maintenance1 1
+#define VK_KHR_MAINTENANCE1_SPEC_VERSION 2
+#define VK_KHR_MAINTENANCE1_EXTENSION_NAME "VK_KHR_maintenance1"
+
+typedef VkCommandPoolTrimFlags VkCommandPoolTrimFlagsKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkTrimCommandPoolKHR)(VkDevice device, VkCommandPool commandPool, VkCommandPoolTrimFlags flags);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkTrimCommandPoolKHR(
+ VkDevice device,
+ VkCommandPool commandPool,
+ VkCommandPoolTrimFlags flags);
+#endif
+
+#define VK_KHR_device_group_creation 1
+#define VK_KHR_DEVICE_GROUP_CREATION_SPEC_VERSION 1
+#define VK_KHR_DEVICE_GROUP_CREATION_EXTENSION_NAME "VK_KHR_device_group_creation"
+#define VK_MAX_DEVICE_GROUP_SIZE_KHR VK_MAX_DEVICE_GROUP_SIZE
+
+typedef VkPhysicalDeviceGroupProperties VkPhysicalDeviceGroupPropertiesKHR;
+
+typedef VkDeviceGroupDeviceCreateInfo VkDeviceGroupDeviceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkEnumeratePhysicalDeviceGroupsKHR)(VkInstance instance, uint32_t* pPhysicalDeviceGroupCount, VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkEnumeratePhysicalDeviceGroupsKHR(
+ VkInstance instance,
+ uint32_t* pPhysicalDeviceGroupCount,
+ VkPhysicalDeviceGroupProperties* pPhysicalDeviceGroupProperties);
+#endif
+
+#define VK_KHR_external_memory_capabilities 1
+#define VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME "VK_KHR_external_memory_capabilities"
+#define VK_LUID_SIZE_KHR VK_LUID_SIZE
+
+typedef VkExternalMemoryHandleTypeFlags VkExternalMemoryHandleTypeFlagsKHR;
+
+typedef VkExternalMemoryHandleTypeFlagBits VkExternalMemoryHandleTypeFlagBitsKHR;
+
+typedef VkExternalMemoryFeatureFlags VkExternalMemoryFeatureFlagsKHR;
+
+typedef VkExternalMemoryFeatureFlagBits VkExternalMemoryFeatureFlagBitsKHR;
+
+
+typedef VkExternalMemoryProperties VkExternalMemoryPropertiesKHR;
+
+typedef VkPhysicalDeviceExternalImageFormatInfo VkPhysicalDeviceExternalImageFormatInfoKHR;
+
+typedef VkExternalImageFormatProperties VkExternalImageFormatPropertiesKHR;
+
+typedef VkPhysicalDeviceExternalBufferInfo VkPhysicalDeviceExternalBufferInfoKHR;
+
+typedef VkExternalBufferProperties VkExternalBufferPropertiesKHR;
+
+typedef VkPhysicalDeviceIDProperties VkPhysicalDeviceIDPropertiesKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalBufferPropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo, VkExternalBufferProperties* pExternalBufferProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalBufferPropertiesKHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceExternalBufferInfo* pExternalBufferInfo,
+ VkExternalBufferProperties* pExternalBufferProperties);
+#endif
+
+#define VK_KHR_external_memory 1
+#define VK_KHR_EXTERNAL_MEMORY_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_MEMORY_EXTENSION_NAME "VK_KHR_external_memory"
+#define VK_QUEUE_FAMILY_EXTERNAL_KHR VK_QUEUE_FAMILY_EXTERNAL
+
+typedef VkExternalMemoryImageCreateInfo VkExternalMemoryImageCreateInfoKHR;
+
+typedef VkExternalMemoryBufferCreateInfo VkExternalMemoryBufferCreateInfoKHR;
+
+typedef VkExportMemoryAllocateInfo VkExportMemoryAllocateInfoKHR;
+
+
+
+#define VK_KHR_external_memory_fd 1
+#define VK_KHR_EXTERNAL_MEMORY_FD_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_MEMORY_FD_EXTENSION_NAME "VK_KHR_external_memory_fd"
+
+typedef struct VkImportMemoryFdInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+ int fd;
+} VkImportMemoryFdInfoKHR;
+
+typedef struct VkMemoryFdPropertiesKHR {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t memoryTypeBits;
+} VkMemoryFdPropertiesKHR;
+
+typedef struct VkMemoryGetFdInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceMemory memory;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+} VkMemoryGetFdInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryFdKHR)(VkDevice device, const VkMemoryGetFdInfoKHR* pGetFdInfo, int* pFd);
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryFdPropertiesKHR)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, int fd, VkMemoryFdPropertiesKHR* pMemoryFdProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryFdKHR(
+ VkDevice device,
+ const VkMemoryGetFdInfoKHR* pGetFdInfo,
+ int* pFd);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryFdPropertiesKHR(
+ VkDevice device,
+ VkExternalMemoryHandleTypeFlagBits handleType,
+ int fd,
+ VkMemoryFdPropertiesKHR* pMemoryFdProperties);
+#endif
+
+#define VK_KHR_external_semaphore_capabilities 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_CAPABILITIES_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_CAPABILITIES_EXTENSION_NAME "VK_KHR_external_semaphore_capabilities"
+
+typedef VkExternalSemaphoreHandleTypeFlags VkExternalSemaphoreHandleTypeFlagsKHR;
+
+typedef VkExternalSemaphoreHandleTypeFlagBits VkExternalSemaphoreHandleTypeFlagBitsKHR;
+
+typedef VkExternalSemaphoreFeatureFlags VkExternalSemaphoreFeatureFlagsKHR;
+
+typedef VkExternalSemaphoreFeatureFlagBits VkExternalSemaphoreFeatureFlagBitsKHR;
+
+
+typedef VkPhysicalDeviceExternalSemaphoreInfo VkPhysicalDeviceExternalSemaphoreInfoKHR;
+
+typedef VkExternalSemaphoreProperties VkExternalSemaphorePropertiesKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalSemaphorePropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo, VkExternalSemaphoreProperties* pExternalSemaphoreProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalSemaphorePropertiesKHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceExternalSemaphoreInfo* pExternalSemaphoreInfo,
+ VkExternalSemaphoreProperties* pExternalSemaphoreProperties);
+#endif
+
+#define VK_KHR_external_semaphore 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_EXTENSION_NAME "VK_KHR_external_semaphore"
+
+typedef VkSemaphoreImportFlags VkSemaphoreImportFlagsKHR;
+
+typedef VkSemaphoreImportFlagBits VkSemaphoreImportFlagBitsKHR;
+
+
+typedef VkExportSemaphoreCreateInfo VkExportSemaphoreCreateInfoKHR;
+
+
+
+#define VK_KHR_external_semaphore_fd 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_FD_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_FD_EXTENSION_NAME "VK_KHR_external_semaphore_fd"
+
+typedef struct VkImportSemaphoreFdInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSemaphore semaphore;
+ VkSemaphoreImportFlags flags;
+ VkExternalSemaphoreHandleTypeFlagBits handleType;
+ int fd;
+} VkImportSemaphoreFdInfoKHR;
+
+typedef struct VkSemaphoreGetFdInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSemaphore semaphore;
+ VkExternalSemaphoreHandleTypeFlagBits handleType;
+} VkSemaphoreGetFdInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkImportSemaphoreFdKHR)(VkDevice device, const VkImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkGetSemaphoreFdKHR)(VkDevice device, const VkSemaphoreGetFdInfoKHR* pGetFdInfo, int* pFd);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkImportSemaphoreFdKHR(
+ VkDevice device,
+ const VkImportSemaphoreFdInfoKHR* pImportSemaphoreFdInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetSemaphoreFdKHR(
+ VkDevice device,
+ const VkSemaphoreGetFdInfoKHR* pGetFdInfo,
+ int* pFd);
+#endif
+
+#define VK_KHR_push_descriptor 1
+#define VK_KHR_PUSH_DESCRIPTOR_SPEC_VERSION 2
+#define VK_KHR_PUSH_DESCRIPTOR_EXTENSION_NAME "VK_KHR_push_descriptor"
+
+typedef struct VkPhysicalDevicePushDescriptorPropertiesKHR {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxPushDescriptors;
+} VkPhysicalDevicePushDescriptorPropertiesKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkCmdPushDescriptorSetKHR)(VkCommandBuffer commandBuffer, VkPipelineBindPoint pipelineBindPoint, VkPipelineLayout layout, uint32_t set, uint32_t descriptorWriteCount, const VkWriteDescriptorSet* pDescriptorWrites);
+typedef void (VKAPI_PTR *PFN_vkCmdPushDescriptorSetWithTemplateKHR)(VkCommandBuffer commandBuffer, VkDescriptorUpdateTemplate descriptorUpdateTemplate, VkPipelineLayout layout, uint32_t set, const void* pData);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdPushDescriptorSetKHR(
+ VkCommandBuffer commandBuffer,
+ VkPipelineBindPoint pipelineBindPoint,
+ VkPipelineLayout layout,
+ uint32_t set,
+ uint32_t descriptorWriteCount,
+ const VkWriteDescriptorSet* pDescriptorWrites);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdPushDescriptorSetWithTemplateKHR(
+ VkCommandBuffer commandBuffer,
+ VkDescriptorUpdateTemplate descriptorUpdateTemplate,
+ VkPipelineLayout layout,
+ uint32_t set,
+ const void* pData);
+#endif
+
+#define VK_KHR_16bit_storage 1
+#define VK_KHR_16BIT_STORAGE_SPEC_VERSION 1
+#define VK_KHR_16BIT_STORAGE_EXTENSION_NAME "VK_KHR_16bit_storage"
+
+typedef VkPhysicalDevice16BitStorageFeatures VkPhysicalDevice16BitStorageFeaturesKHR;
+
+
+
+#define VK_KHR_incremental_present 1
+#define VK_KHR_INCREMENTAL_PRESENT_SPEC_VERSION 1
+#define VK_KHR_INCREMENTAL_PRESENT_EXTENSION_NAME "VK_KHR_incremental_present"
+
+typedef struct VkRectLayerKHR {
+ VkOffset2D offset;
+ VkExtent2D extent;
+ uint32_t layer;
+} VkRectLayerKHR;
+
+typedef struct VkPresentRegionKHR {
+ uint32_t rectangleCount;
+ const VkRectLayerKHR* pRectangles;
+} VkPresentRegionKHR;
+
+typedef struct VkPresentRegionsKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t swapchainCount;
+ const VkPresentRegionKHR* pRegions;
+} VkPresentRegionsKHR;
+
+
+
+#define VK_KHR_descriptor_update_template 1
+typedef VkDescriptorUpdateTemplate VkDescriptorUpdateTemplateKHR;
+
+
+#define VK_KHR_DESCRIPTOR_UPDATE_TEMPLATE_SPEC_VERSION 1
+#define VK_KHR_DESCRIPTOR_UPDATE_TEMPLATE_EXTENSION_NAME "VK_KHR_descriptor_update_template"
+
+typedef VkDescriptorUpdateTemplateType VkDescriptorUpdateTemplateTypeKHR;
+
+
+typedef VkDescriptorUpdateTemplateCreateFlags VkDescriptorUpdateTemplateCreateFlagsKHR;
+
+
+typedef VkDescriptorUpdateTemplateEntry VkDescriptorUpdateTemplateEntryKHR;
+
+typedef VkDescriptorUpdateTemplateCreateInfo VkDescriptorUpdateTemplateCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDescriptorUpdateTemplateKHR)(VkDevice device, const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate);
+typedef void (VKAPI_PTR *PFN_vkDestroyDescriptorUpdateTemplateKHR)(VkDevice device, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const VkAllocationCallbacks* pAllocator);
+typedef void (VKAPI_PTR *PFN_vkUpdateDescriptorSetWithTemplateKHR)(VkDevice device, VkDescriptorSet descriptorSet, VkDescriptorUpdateTemplate descriptorUpdateTemplate, const void* pData);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDescriptorUpdateTemplateKHR(
+ VkDevice device,
+ const VkDescriptorUpdateTemplateCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDescriptorUpdateTemplate* pDescriptorUpdateTemplate);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDescriptorUpdateTemplateKHR(
+ VkDevice device,
+ VkDescriptorUpdateTemplate descriptorUpdateTemplate,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR void VKAPI_CALL vkUpdateDescriptorSetWithTemplateKHR(
+ VkDevice device,
+ VkDescriptorSet descriptorSet,
+ VkDescriptorUpdateTemplate descriptorUpdateTemplate,
+ const void* pData);
+#endif
+
+#define VK_KHR_shared_presentable_image 1
+#define VK_KHR_SHARED_PRESENTABLE_IMAGE_SPEC_VERSION 1
+#define VK_KHR_SHARED_PRESENTABLE_IMAGE_EXTENSION_NAME "VK_KHR_shared_presentable_image"
+
+typedef struct VkSharedPresentSurfaceCapabilitiesKHR {
+ VkStructureType sType;
+ void* pNext;
+ VkImageUsageFlags sharedPresentSupportedUsageFlags;
+} VkSharedPresentSurfaceCapabilitiesKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainStatusKHR)(VkDevice device, VkSwapchainKHR swapchain);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainStatusKHR(
+ VkDevice device,
+ VkSwapchainKHR swapchain);
+#endif
+
+#define VK_KHR_external_fence_capabilities 1
+#define VK_KHR_EXTERNAL_FENCE_CAPABILITIES_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_FENCE_CAPABILITIES_EXTENSION_NAME "VK_KHR_external_fence_capabilities"
+
+typedef VkExternalFenceHandleTypeFlags VkExternalFenceHandleTypeFlagsKHR;
+
+typedef VkExternalFenceHandleTypeFlagBits VkExternalFenceHandleTypeFlagBitsKHR;
+
+typedef VkExternalFenceFeatureFlags VkExternalFenceFeatureFlagsKHR;
+
+typedef VkExternalFenceFeatureFlagBits VkExternalFenceFeatureFlagBitsKHR;
+
+
+typedef VkPhysicalDeviceExternalFenceInfo VkPhysicalDeviceExternalFenceInfoKHR;
+
+typedef VkExternalFenceProperties VkExternalFencePropertiesKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalFencePropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo, VkExternalFenceProperties* pExternalFenceProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceExternalFencePropertiesKHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceExternalFenceInfo* pExternalFenceInfo,
+ VkExternalFenceProperties* pExternalFenceProperties);
+#endif
+
+#define VK_KHR_external_fence 1
+#define VK_KHR_EXTERNAL_FENCE_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_FENCE_EXTENSION_NAME "VK_KHR_external_fence"
+
+typedef VkFenceImportFlags VkFenceImportFlagsKHR;
+
+typedef VkFenceImportFlagBits VkFenceImportFlagBitsKHR;
+
+
+typedef VkExportFenceCreateInfo VkExportFenceCreateInfoKHR;
+
+
+
+#define VK_KHR_external_fence_fd 1
+#define VK_KHR_EXTERNAL_FENCE_FD_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_FENCE_FD_EXTENSION_NAME "VK_KHR_external_fence_fd"
+
+typedef struct VkImportFenceFdInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkFence fence;
+ VkFenceImportFlags flags;
+ VkExternalFenceHandleTypeFlagBits handleType;
+ int fd;
+} VkImportFenceFdInfoKHR;
+
+typedef struct VkFenceGetFdInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkFence fence;
+ VkExternalFenceHandleTypeFlagBits handleType;
+} VkFenceGetFdInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkImportFenceFdKHR)(VkDevice device, const VkImportFenceFdInfoKHR* pImportFenceFdInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkGetFenceFdKHR)(VkDevice device, const VkFenceGetFdInfoKHR* pGetFdInfo, int* pFd);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkImportFenceFdKHR(
+ VkDevice device,
+ const VkImportFenceFdInfoKHR* pImportFenceFdInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetFenceFdKHR(
+ VkDevice device,
+ const VkFenceGetFdInfoKHR* pGetFdInfo,
+ int* pFd);
+#endif
+
+#define VK_KHR_maintenance2 1
+#define VK_KHR_MAINTENANCE2_SPEC_VERSION 1
+#define VK_KHR_MAINTENANCE2_EXTENSION_NAME "VK_KHR_maintenance2"
+
+typedef VkPointClippingBehavior VkPointClippingBehaviorKHR;
+
+typedef VkTessellationDomainOrigin VkTessellationDomainOriginKHR;
+
+
+typedef VkPhysicalDevicePointClippingProperties VkPhysicalDevicePointClippingPropertiesKHR;
+
+typedef VkRenderPassInputAttachmentAspectCreateInfo VkRenderPassInputAttachmentAspectCreateInfoKHR;
+
+typedef VkInputAttachmentAspectReference VkInputAttachmentAspectReferenceKHR;
+
+typedef VkImageViewUsageCreateInfo VkImageViewUsageCreateInfoKHR;
+
+typedef VkPipelineTessellationDomainOriginStateCreateInfo VkPipelineTessellationDomainOriginStateCreateInfoKHR;
+
+
+
+#define VK_KHR_get_surface_capabilities2 1
+#define VK_KHR_GET_SURFACE_CAPABILITIES_2_SPEC_VERSION 1
+#define VK_KHR_GET_SURFACE_CAPABILITIES_2_EXTENSION_NAME "VK_KHR_get_surface_capabilities2"
+
+typedef struct VkPhysicalDeviceSurfaceInfo2KHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSurfaceKHR surface;
+} VkPhysicalDeviceSurfaceInfo2KHR;
+
+typedef struct VkSurfaceCapabilities2KHR {
+ VkStructureType sType;
+ void* pNext;
+ VkSurfaceCapabilitiesKHR surfaceCapabilities;
+} VkSurfaceCapabilities2KHR;
+
+typedef struct VkSurfaceFormat2KHR {
+ VkStructureType sType;
+ void* pNext;
+ VkSurfaceFormatKHR surfaceFormat;
+} VkSurfaceFormat2KHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilities2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, VkSurfaceCapabilities2KHR* pSurfaceCapabilities);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceFormats2KHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo, uint32_t* pSurfaceFormatCount, VkSurfaceFormat2KHR* pSurfaceFormats);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilities2KHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo,
+ VkSurfaceCapabilities2KHR* pSurfaceCapabilities);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceFormats2KHR(
+ VkPhysicalDevice physicalDevice,
+ const VkPhysicalDeviceSurfaceInfo2KHR* pSurfaceInfo,
+ uint32_t* pSurfaceFormatCount,
+ VkSurfaceFormat2KHR* pSurfaceFormats);
+#endif
+
+#define VK_KHR_variable_pointers 1
+#define VK_KHR_VARIABLE_POINTERS_SPEC_VERSION 1
+#define VK_KHR_VARIABLE_POINTERS_EXTENSION_NAME "VK_KHR_variable_pointers"
+
+typedef VkPhysicalDeviceVariablePointerFeatures VkPhysicalDeviceVariablePointerFeaturesKHR;
+
+
+
+#define VK_KHR_dedicated_allocation 1
+#define VK_KHR_DEDICATED_ALLOCATION_SPEC_VERSION 3
+#define VK_KHR_DEDICATED_ALLOCATION_EXTENSION_NAME "VK_KHR_dedicated_allocation"
+
+typedef VkMemoryDedicatedRequirements VkMemoryDedicatedRequirementsKHR;
+
+typedef VkMemoryDedicatedAllocateInfo VkMemoryDedicatedAllocateInfoKHR;
+
+
+
+#define VK_KHR_storage_buffer_storage_class 1
+#define VK_KHR_STORAGE_BUFFER_STORAGE_CLASS_SPEC_VERSION 1
+#define VK_KHR_STORAGE_BUFFER_STORAGE_CLASS_EXTENSION_NAME "VK_KHR_storage_buffer_storage_class"
+
+
+#define VK_KHR_relaxed_block_layout 1
+#define VK_KHR_RELAXED_BLOCK_LAYOUT_SPEC_VERSION 1
+#define VK_KHR_RELAXED_BLOCK_LAYOUT_EXTENSION_NAME "VK_KHR_relaxed_block_layout"
+
+
+#define VK_KHR_get_memory_requirements2 1
+#define VK_KHR_GET_MEMORY_REQUIREMENTS_2_SPEC_VERSION 1
+#define VK_KHR_GET_MEMORY_REQUIREMENTS_2_EXTENSION_NAME "VK_KHR_get_memory_requirements2"
+
+typedef VkBufferMemoryRequirementsInfo2 VkBufferMemoryRequirementsInfo2KHR;
+
+typedef VkImageMemoryRequirementsInfo2 VkImageMemoryRequirementsInfo2KHR;
+
+typedef VkImageSparseMemoryRequirementsInfo2 VkImageSparseMemoryRequirementsInfo2KHR;
+
+typedef VkMemoryRequirements2 VkMemoryRequirements2KHR;
+
+typedef VkSparseImageMemoryRequirements2 VkSparseImageMemoryRequirements2KHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetImageMemoryRequirements2KHR)(VkDevice device, const VkImageMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetBufferMemoryRequirements2KHR)(VkDevice device, const VkBufferMemoryRequirementsInfo2* pInfo, VkMemoryRequirements2* pMemoryRequirements);
+typedef void (VKAPI_PTR *PFN_vkGetImageSparseMemoryRequirements2KHR)(VkDevice device, const VkImageSparseMemoryRequirementsInfo2* pInfo, uint32_t* pSparseMemoryRequirementCount, VkSparseImageMemoryRequirements2* pSparseMemoryRequirements);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetImageMemoryRequirements2KHR(
+ VkDevice device,
+ const VkImageMemoryRequirementsInfo2* pInfo,
+ VkMemoryRequirements2* pMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetBufferMemoryRequirements2KHR(
+ VkDevice device,
+ const VkBufferMemoryRequirementsInfo2* pInfo,
+ VkMemoryRequirements2* pMemoryRequirements);
+
+VKAPI_ATTR void VKAPI_CALL vkGetImageSparseMemoryRequirements2KHR(
+ VkDevice device,
+ const VkImageSparseMemoryRequirementsInfo2* pInfo,
+ uint32_t* pSparseMemoryRequirementCount,
+ VkSparseImageMemoryRequirements2* pSparseMemoryRequirements);
+#endif
+
+#define VK_KHR_image_format_list 1
+#define VK_KHR_IMAGE_FORMAT_LIST_SPEC_VERSION 1
+#define VK_KHR_IMAGE_FORMAT_LIST_EXTENSION_NAME "VK_KHR_image_format_list"
+
+typedef struct VkImageFormatListCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t viewFormatCount;
+ const VkFormat* pViewFormats;
+} VkImageFormatListCreateInfoKHR;
+
+
+
+#define VK_KHR_sampler_ycbcr_conversion 1
+typedef VkSamplerYcbcrConversion VkSamplerYcbcrConversionKHR;
+
+
+#define VK_KHR_SAMPLER_YCBCR_CONVERSION_SPEC_VERSION 1
+#define VK_KHR_SAMPLER_YCBCR_CONVERSION_EXTENSION_NAME "VK_KHR_sampler_ycbcr_conversion"
+
+typedef VkSamplerYcbcrModelConversion VkSamplerYcbcrModelConversionKHR;
+
+typedef VkSamplerYcbcrRange VkSamplerYcbcrRangeKHR;
+
+typedef VkChromaLocation VkChromaLocationKHR;
+
+
+typedef VkSamplerYcbcrConversionCreateInfo VkSamplerYcbcrConversionCreateInfoKHR;
+
+typedef VkSamplerYcbcrConversionInfo VkSamplerYcbcrConversionInfoKHR;
+
+typedef VkBindImagePlaneMemoryInfo VkBindImagePlaneMemoryInfoKHR;
+
+typedef VkImagePlaneMemoryRequirementsInfo VkImagePlaneMemoryRequirementsInfoKHR;
+
+typedef VkPhysicalDeviceSamplerYcbcrConversionFeatures VkPhysicalDeviceSamplerYcbcrConversionFeaturesKHR;
+
+typedef VkSamplerYcbcrConversionImageFormatProperties VkSamplerYcbcrConversionImageFormatPropertiesKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateSamplerYcbcrConversionKHR)(VkDevice device, const VkSamplerYcbcrConversionCreateInfo* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSamplerYcbcrConversion* pYcbcrConversion);
+typedef void (VKAPI_PTR *PFN_vkDestroySamplerYcbcrConversionKHR)(VkDevice device, VkSamplerYcbcrConversion ycbcrConversion, const VkAllocationCallbacks* pAllocator);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateSamplerYcbcrConversionKHR(
+ VkDevice device,
+ const VkSamplerYcbcrConversionCreateInfo* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSamplerYcbcrConversion* pYcbcrConversion);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroySamplerYcbcrConversionKHR(
+ VkDevice device,
+ VkSamplerYcbcrConversion ycbcrConversion,
+ const VkAllocationCallbacks* pAllocator);
+#endif
+
+#define VK_KHR_bind_memory2 1
+#define VK_KHR_BIND_MEMORY_2_SPEC_VERSION 1
+#define VK_KHR_BIND_MEMORY_2_EXTENSION_NAME "VK_KHR_bind_memory2"
+
+typedef VkBindBufferMemoryInfo VkBindBufferMemoryInfoKHR;
+
+typedef VkBindImageMemoryInfo VkBindImageMemoryInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkBindBufferMemory2KHR)(VkDevice device, uint32_t bindInfoCount, const VkBindBufferMemoryInfo* pBindInfos);
+typedef VkResult (VKAPI_PTR *PFN_vkBindImageMemory2KHR)(VkDevice device, uint32_t bindInfoCount, const VkBindImageMemoryInfo* pBindInfos);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkBindBufferMemory2KHR(
+ VkDevice device,
+ uint32_t bindInfoCount,
+ const VkBindBufferMemoryInfo* pBindInfos);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkBindImageMemory2KHR(
+ VkDevice device,
+ uint32_t bindInfoCount,
+ const VkBindImageMemoryInfo* pBindInfos);
+#endif
+
+#define VK_KHR_maintenance3 1
+#define VK_KHR_MAINTENANCE3_SPEC_VERSION 1
+#define VK_KHR_MAINTENANCE3_EXTENSION_NAME "VK_KHR_maintenance3"
+
+typedef VkPhysicalDeviceMaintenance3Properties VkPhysicalDeviceMaintenance3PropertiesKHR;
+
+typedef VkDescriptorSetLayoutSupport VkDescriptorSetLayoutSupportKHR;
+
+
+typedef void (VKAPI_PTR *PFN_vkGetDescriptorSetLayoutSupportKHR)(VkDevice device, const VkDescriptorSetLayoutCreateInfo* pCreateInfo, VkDescriptorSetLayoutSupport* pSupport);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkGetDescriptorSetLayoutSupportKHR(
+ VkDevice device,
+ const VkDescriptorSetLayoutCreateInfo* pCreateInfo,
+ VkDescriptorSetLayoutSupport* pSupport);
+#endif
+
+#define VK_EXT_debug_report 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDebugReportCallbackEXT)
+
+#define VK_EXT_DEBUG_REPORT_SPEC_VERSION 9
+#define VK_EXT_DEBUG_REPORT_EXTENSION_NAME "VK_EXT_debug_report"
+#define VK_STRUCTURE_TYPE_DEBUG_REPORT_CREATE_INFO_EXT VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT
+#define VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_EXT VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT
+
+
+typedef enum VkDebugReportObjectTypeEXT {
+ VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT = 0,
+ VK_DEBUG_REPORT_OBJECT_TYPE_INSTANCE_EXT = 1,
+ VK_DEBUG_REPORT_OBJECT_TYPE_PHYSICAL_DEVICE_EXT = 2,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_EXT = 3,
+ VK_DEBUG_REPORT_OBJECT_TYPE_QUEUE_EXT = 4,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SEMAPHORE_EXT = 5,
+ VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_BUFFER_EXT = 6,
+ VK_DEBUG_REPORT_OBJECT_TYPE_FENCE_EXT = 7,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMORY_EXT = 8,
+ VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT = 9,
+ VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT = 10,
+ VK_DEBUG_REPORT_OBJECT_TYPE_EVENT_EXT = 11,
+ VK_DEBUG_REPORT_OBJECT_TYPE_QUERY_POOL_EXT = 12,
+ VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_VIEW_EXT = 13,
+ VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_VIEW_EXT = 14,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SHADER_MODULE_EXT = 15,
+ VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_CACHE_EXT = 16,
+ VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_LAYOUT_EXT = 17,
+ VK_DEBUG_REPORT_OBJECT_TYPE_RENDER_PASS_EXT = 18,
+ VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT = 19,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT_EXT = 20,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_EXT = 21,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_POOL_EXT = 22,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_EXT = 23,
+ VK_DEBUG_REPORT_OBJECT_TYPE_FRAMEBUFFER_EXT = 24,
+ VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_POOL_EXT = 25,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SURFACE_KHR_EXT = 26,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SWAPCHAIN_KHR_EXT = 27,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT = 28,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_KHR_EXT = 29,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_MODE_KHR_EXT = 30,
+ VK_DEBUG_REPORT_OBJECT_TYPE_OBJECT_TABLE_NVX_EXT = 31,
+ VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT = 32,
+ VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT = 33,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT = 1000156000,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT = 1000085000,
+ VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_KHR_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT,
+ VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_KHR_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT,
+ VK_DEBUG_REPORT_OBJECT_TYPE_BEGIN_RANGE_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT,
+ VK_DEBUG_REPORT_OBJECT_TYPE_END_RANGE_EXT = VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT,
+ VK_DEBUG_REPORT_OBJECT_TYPE_RANGE_SIZE_EXT = (VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT - VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT + 1),
+ VK_DEBUG_REPORT_OBJECT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDebugReportObjectTypeEXT;
+
+
+typedef enum VkDebugReportFlagBitsEXT {
+ VK_DEBUG_REPORT_INFORMATION_BIT_EXT = 0x00000001,
+ VK_DEBUG_REPORT_WARNING_BIT_EXT = 0x00000002,
+ VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT = 0x00000004,
+ VK_DEBUG_REPORT_ERROR_BIT_EXT = 0x00000008,
+ VK_DEBUG_REPORT_DEBUG_BIT_EXT = 0x00000010,
+ VK_DEBUG_REPORT_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDebugReportFlagBitsEXT;
+typedef VkFlags VkDebugReportFlagsEXT;
+
+typedef VkBool32 (VKAPI_PTR *PFN_vkDebugReportCallbackEXT)(
+ VkDebugReportFlagsEXT flags,
+ VkDebugReportObjectTypeEXT objectType,
+ uint64_t object,
+ size_t location,
+ int32_t messageCode,
+ const char* pLayerPrefix,
+ const char* pMessage,
+ void* pUserData);
+
+typedef struct VkDebugReportCallbackCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDebugReportFlagsEXT flags;
+ PFN_vkDebugReportCallbackEXT pfnCallback;
+ void* pUserData;
+} VkDebugReportCallbackCreateInfoEXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDebugReportCallbackEXT)(VkInstance instance, const VkDebugReportCallbackCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugReportCallbackEXT* pCallback);
+typedef void (VKAPI_PTR *PFN_vkDestroyDebugReportCallbackEXT)(VkInstance instance, VkDebugReportCallbackEXT callback, const VkAllocationCallbacks* pAllocator);
+typedef void (VKAPI_PTR *PFN_vkDebugReportMessageEXT)(VkInstance instance, VkDebugReportFlagsEXT flags, VkDebugReportObjectTypeEXT objectType, uint64_t object, size_t location, int32_t messageCode, const char* pLayerPrefix, const char* pMessage);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDebugReportCallbackEXT(
+ VkInstance instance,
+ const VkDebugReportCallbackCreateInfoEXT* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDebugReportCallbackEXT* pCallback);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDebugReportCallbackEXT(
+ VkInstance instance,
+ VkDebugReportCallbackEXT callback,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR void VKAPI_CALL vkDebugReportMessageEXT(
+ VkInstance instance,
+ VkDebugReportFlagsEXT flags,
+ VkDebugReportObjectTypeEXT objectType,
+ uint64_t object,
+ size_t location,
+ int32_t messageCode,
+ const char* pLayerPrefix,
+ const char* pMessage);
+#endif
+
+#define VK_NV_glsl_shader 1
+#define VK_NV_GLSL_SHADER_SPEC_VERSION 1
+#define VK_NV_GLSL_SHADER_EXTENSION_NAME "VK_NV_glsl_shader"
+
+
+#define VK_EXT_depth_range_unrestricted 1
+#define VK_EXT_DEPTH_RANGE_UNRESTRICTED_SPEC_VERSION 1
+#define VK_EXT_DEPTH_RANGE_UNRESTRICTED_EXTENSION_NAME "VK_EXT_depth_range_unrestricted"
+
+
+#define VK_IMG_filter_cubic 1
+#define VK_IMG_FILTER_CUBIC_SPEC_VERSION 1
+#define VK_IMG_FILTER_CUBIC_EXTENSION_NAME "VK_IMG_filter_cubic"
+
+
+#define VK_AMD_rasterization_order 1
+#define VK_AMD_RASTERIZATION_ORDER_SPEC_VERSION 1
+#define VK_AMD_RASTERIZATION_ORDER_EXTENSION_NAME "VK_AMD_rasterization_order"
+
+
+typedef enum VkRasterizationOrderAMD {
+ VK_RASTERIZATION_ORDER_STRICT_AMD = 0,
+ VK_RASTERIZATION_ORDER_RELAXED_AMD = 1,
+ VK_RASTERIZATION_ORDER_BEGIN_RANGE_AMD = VK_RASTERIZATION_ORDER_STRICT_AMD,
+ VK_RASTERIZATION_ORDER_END_RANGE_AMD = VK_RASTERIZATION_ORDER_RELAXED_AMD,
+ VK_RASTERIZATION_ORDER_RANGE_SIZE_AMD = (VK_RASTERIZATION_ORDER_RELAXED_AMD - VK_RASTERIZATION_ORDER_STRICT_AMD + 1),
+ VK_RASTERIZATION_ORDER_MAX_ENUM_AMD = 0x7FFFFFFF
+} VkRasterizationOrderAMD;
+
+typedef struct VkPipelineRasterizationStateRasterizationOrderAMD {
+ VkStructureType sType;
+ const void* pNext;
+ VkRasterizationOrderAMD rasterizationOrder;
+} VkPipelineRasterizationStateRasterizationOrderAMD;
+
+
+
+#define VK_AMD_shader_trinary_minmax 1
+#define VK_AMD_SHADER_TRINARY_MINMAX_SPEC_VERSION 1
+#define VK_AMD_SHADER_TRINARY_MINMAX_EXTENSION_NAME "VK_AMD_shader_trinary_minmax"
+
+
+#define VK_AMD_shader_explicit_vertex_parameter 1
+#define VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_SPEC_VERSION 1
+#define VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_EXTENSION_NAME "VK_AMD_shader_explicit_vertex_parameter"
+
+
+#define VK_EXT_debug_marker 1
+#define VK_EXT_DEBUG_MARKER_SPEC_VERSION 4
+#define VK_EXT_DEBUG_MARKER_EXTENSION_NAME "VK_EXT_debug_marker"
+
+typedef struct VkDebugMarkerObjectNameInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDebugReportObjectTypeEXT objectType;
+ uint64_t object;
+ const char* pObjectName;
+} VkDebugMarkerObjectNameInfoEXT;
+
+typedef struct VkDebugMarkerObjectTagInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDebugReportObjectTypeEXT objectType;
+ uint64_t object;
+ uint64_t tagName;
+ size_t tagSize;
+ const void* pTag;
+} VkDebugMarkerObjectTagInfoEXT;
+
+typedef struct VkDebugMarkerMarkerInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ const char* pMarkerName;
+ float color[4];
+} VkDebugMarkerMarkerInfoEXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkDebugMarkerSetObjectTagEXT)(VkDevice device, const VkDebugMarkerObjectTagInfoEXT* pTagInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkDebugMarkerSetObjectNameEXT)(VkDevice device, const VkDebugMarkerObjectNameInfoEXT* pNameInfo);
+typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerBeginEXT)(VkCommandBuffer commandBuffer, const VkDebugMarkerMarkerInfoEXT* pMarkerInfo);
+typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerEndEXT)(VkCommandBuffer commandBuffer);
+typedef void (VKAPI_PTR *PFN_vkCmdDebugMarkerInsertEXT)(VkCommandBuffer commandBuffer, const VkDebugMarkerMarkerInfoEXT* pMarkerInfo);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkDebugMarkerSetObjectTagEXT(
+ VkDevice device,
+ const VkDebugMarkerObjectTagInfoEXT* pTagInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkDebugMarkerSetObjectNameEXT(
+ VkDevice device,
+ const VkDebugMarkerObjectNameInfoEXT* pNameInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerBeginEXT(
+ VkCommandBuffer commandBuffer,
+ const VkDebugMarkerMarkerInfoEXT* pMarkerInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerEndEXT(
+ VkCommandBuffer commandBuffer);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDebugMarkerInsertEXT(
+ VkCommandBuffer commandBuffer,
+ const VkDebugMarkerMarkerInfoEXT* pMarkerInfo);
+#endif
+
+#define VK_AMD_gcn_shader 1
+#define VK_AMD_GCN_SHADER_SPEC_VERSION 1
+#define VK_AMD_GCN_SHADER_EXTENSION_NAME "VK_AMD_gcn_shader"
+
+
+#define VK_NV_dedicated_allocation 1
+#define VK_NV_DEDICATED_ALLOCATION_SPEC_VERSION 1
+#define VK_NV_DEDICATED_ALLOCATION_EXTENSION_NAME "VK_NV_dedicated_allocation"
+
+typedef struct VkDedicatedAllocationImageCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 dedicatedAllocation;
+} VkDedicatedAllocationImageCreateInfoNV;
+
+typedef struct VkDedicatedAllocationBufferCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 dedicatedAllocation;
+} VkDedicatedAllocationBufferCreateInfoNV;
+
+typedef struct VkDedicatedAllocationMemoryAllocateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkImage image;
+ VkBuffer buffer;
+} VkDedicatedAllocationMemoryAllocateInfoNV;
+
+
+
+#define VK_AMD_draw_indirect_count 1
+#define VK_AMD_DRAW_INDIRECT_COUNT_SPEC_VERSION 1
+#define VK_AMD_DRAW_INDIRECT_COUNT_EXTENSION_NAME "VK_AMD_draw_indirect_count"
+
+typedef void (VKAPI_PTR *PFN_vkCmdDrawIndirectCountAMD)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride);
+typedef void (VKAPI_PTR *PFN_vkCmdDrawIndexedIndirectCountAMD)(VkCommandBuffer commandBuffer, VkBuffer buffer, VkDeviceSize offset, VkBuffer countBuffer, VkDeviceSize countBufferOffset, uint32_t maxDrawCount, uint32_t stride);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndirectCountAMD(
+ VkCommandBuffer commandBuffer,
+ VkBuffer buffer,
+ VkDeviceSize offset,
+ VkBuffer countBuffer,
+ VkDeviceSize countBufferOffset,
+ uint32_t maxDrawCount,
+ uint32_t stride);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdDrawIndexedIndirectCountAMD(
+ VkCommandBuffer commandBuffer,
+ VkBuffer buffer,
+ VkDeviceSize offset,
+ VkBuffer countBuffer,
+ VkDeviceSize countBufferOffset,
+ uint32_t maxDrawCount,
+ uint32_t stride);
+#endif
+
+#define VK_AMD_negative_viewport_height 1
+#define VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_SPEC_VERSION 1
+#define VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_EXTENSION_NAME "VK_AMD_negative_viewport_height"
+
+
+#define VK_AMD_gpu_shader_half_float 1
+#define VK_AMD_GPU_SHADER_HALF_FLOAT_SPEC_VERSION 1
+#define VK_AMD_GPU_SHADER_HALF_FLOAT_EXTENSION_NAME "VK_AMD_gpu_shader_half_float"
+
+
+#define VK_AMD_shader_ballot 1
+#define VK_AMD_SHADER_BALLOT_SPEC_VERSION 1
+#define VK_AMD_SHADER_BALLOT_EXTENSION_NAME "VK_AMD_shader_ballot"
+
+
+#define VK_AMD_texture_gather_bias_lod 1
+#define VK_AMD_TEXTURE_GATHER_BIAS_LOD_SPEC_VERSION 1
+#define VK_AMD_TEXTURE_GATHER_BIAS_LOD_EXTENSION_NAME "VK_AMD_texture_gather_bias_lod"
+
+typedef struct VkTextureLODGatherFormatPropertiesAMD {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 supportsTextureGatherLODBiasAMD;
+} VkTextureLODGatherFormatPropertiesAMD;
+
+
+
+#define VK_AMD_shader_info 1
+#define VK_AMD_SHADER_INFO_SPEC_VERSION 1
+#define VK_AMD_SHADER_INFO_EXTENSION_NAME "VK_AMD_shader_info"
+
+
+typedef enum VkShaderInfoTypeAMD {
+ VK_SHADER_INFO_TYPE_STATISTICS_AMD = 0,
+ VK_SHADER_INFO_TYPE_BINARY_AMD = 1,
+ VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD = 2,
+ VK_SHADER_INFO_TYPE_BEGIN_RANGE_AMD = VK_SHADER_INFO_TYPE_STATISTICS_AMD,
+ VK_SHADER_INFO_TYPE_END_RANGE_AMD = VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD,
+ VK_SHADER_INFO_TYPE_RANGE_SIZE_AMD = (VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD - VK_SHADER_INFO_TYPE_STATISTICS_AMD + 1),
+ VK_SHADER_INFO_TYPE_MAX_ENUM_AMD = 0x7FFFFFFF
+} VkShaderInfoTypeAMD;
+
+typedef struct VkShaderResourceUsageAMD {
+ uint32_t numUsedVgprs;
+ uint32_t numUsedSgprs;
+ uint32_t ldsSizePerLocalWorkGroup;
+ size_t ldsUsageSizeInBytes;
+ size_t scratchMemUsageInBytes;
+} VkShaderResourceUsageAMD;
+
+typedef struct VkShaderStatisticsInfoAMD {
+ VkShaderStageFlags shaderStageMask;
+ VkShaderResourceUsageAMD resourceUsage;
+ uint32_t numPhysicalVgprs;
+ uint32_t numPhysicalSgprs;
+ uint32_t numAvailableVgprs;
+ uint32_t numAvailableSgprs;
+ uint32_t computeWorkGroupSize[3];
+} VkShaderStatisticsInfoAMD;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetShaderInfoAMD)(VkDevice device, VkPipeline pipeline, VkShaderStageFlagBits shaderStage, VkShaderInfoTypeAMD infoType, size_t* pInfoSize, void* pInfo);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetShaderInfoAMD(
+ VkDevice device,
+ VkPipeline pipeline,
+ VkShaderStageFlagBits shaderStage,
+ VkShaderInfoTypeAMD infoType,
+ size_t* pInfoSize,
+ void* pInfo);
+#endif
+
+#define VK_AMD_shader_image_load_store_lod 1
+#define VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_SPEC_VERSION 1
+#define VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_EXTENSION_NAME "VK_AMD_shader_image_load_store_lod"
+
+
+#define VK_IMG_format_pvrtc 1
+#define VK_IMG_FORMAT_PVRTC_SPEC_VERSION 1
+#define VK_IMG_FORMAT_PVRTC_EXTENSION_NAME "VK_IMG_format_pvrtc"
+
+
+#define VK_NV_external_memory_capabilities 1
+#define VK_NV_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION 1
+#define VK_NV_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME "VK_NV_external_memory_capabilities"
+
+
+typedef enum VkExternalMemoryHandleTypeFlagBitsNV {
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_NV = 0x00000001,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_NV = 0x00000002,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_BIT_NV = 0x00000004,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_KMT_BIT_NV = 0x00000008,
+ VK_EXTERNAL_MEMORY_HANDLE_TYPE_FLAG_BITS_MAX_ENUM_NV = 0x7FFFFFFF
+} VkExternalMemoryHandleTypeFlagBitsNV;
+typedef VkFlags VkExternalMemoryHandleTypeFlagsNV;
+
+typedef enum VkExternalMemoryFeatureFlagBitsNV {
+ VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_NV = 0x00000001,
+ VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_NV = 0x00000002,
+ VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_NV = 0x00000004,
+ VK_EXTERNAL_MEMORY_FEATURE_FLAG_BITS_MAX_ENUM_NV = 0x7FFFFFFF
+} VkExternalMemoryFeatureFlagBitsNV;
+typedef VkFlags VkExternalMemoryFeatureFlagsNV;
+
+typedef struct VkExternalImageFormatPropertiesNV {
+ VkImageFormatProperties imageFormatProperties;
+ VkExternalMemoryFeatureFlagsNV externalMemoryFeatures;
+ VkExternalMemoryHandleTypeFlagsNV exportFromImportedHandleTypes;
+ VkExternalMemoryHandleTypeFlagsNV compatibleHandleTypes;
+} VkExternalImageFormatPropertiesNV;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV)(VkPhysicalDevice physicalDevice, VkFormat format, VkImageType type, VkImageTiling tiling, VkImageUsageFlags usage, VkImageCreateFlags flags, VkExternalMemoryHandleTypeFlagsNV externalHandleType, VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceExternalImageFormatPropertiesNV(
+ VkPhysicalDevice physicalDevice,
+ VkFormat format,
+ VkImageType type,
+ VkImageTiling tiling,
+ VkImageUsageFlags usage,
+ VkImageCreateFlags flags,
+ VkExternalMemoryHandleTypeFlagsNV externalHandleType,
+ VkExternalImageFormatPropertiesNV* pExternalImageFormatProperties);
+#endif
+
+#define VK_NV_external_memory 1
+#define VK_NV_EXTERNAL_MEMORY_SPEC_VERSION 1
+#define VK_NV_EXTERNAL_MEMORY_EXTENSION_NAME "VK_NV_external_memory"
+
+typedef struct VkExternalMemoryImageCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagsNV handleTypes;
+} VkExternalMemoryImageCreateInfoNV;
+
+typedef struct VkExportMemoryAllocateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagsNV handleTypes;
+} VkExportMemoryAllocateInfoNV;
+
+
+
+#define VK_EXT_validation_flags 1
+#define VK_EXT_VALIDATION_FLAGS_SPEC_VERSION 1
+#define VK_EXT_VALIDATION_FLAGS_EXTENSION_NAME "VK_EXT_validation_flags"
+
+
+typedef enum VkValidationCheckEXT {
+ VK_VALIDATION_CHECK_ALL_EXT = 0,
+ VK_VALIDATION_CHECK_SHADERS_EXT = 1,
+ VK_VALIDATION_CHECK_BEGIN_RANGE_EXT = VK_VALIDATION_CHECK_ALL_EXT,
+ VK_VALIDATION_CHECK_END_RANGE_EXT = VK_VALIDATION_CHECK_SHADERS_EXT,
+ VK_VALIDATION_CHECK_RANGE_SIZE_EXT = (VK_VALIDATION_CHECK_SHADERS_EXT - VK_VALIDATION_CHECK_ALL_EXT + 1),
+ VK_VALIDATION_CHECK_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkValidationCheckEXT;
+
+typedef struct VkValidationFlagsEXT {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t disabledValidationCheckCount;
+ VkValidationCheckEXT* pDisabledValidationChecks;
+} VkValidationFlagsEXT;
+
+
+
+#define VK_EXT_shader_subgroup_ballot 1
+#define VK_EXT_SHADER_SUBGROUP_BALLOT_SPEC_VERSION 1
+#define VK_EXT_SHADER_SUBGROUP_BALLOT_EXTENSION_NAME "VK_EXT_shader_subgroup_ballot"
+
+
+#define VK_EXT_shader_subgroup_vote 1
+#define VK_EXT_SHADER_SUBGROUP_VOTE_SPEC_VERSION 1
+#define VK_EXT_SHADER_SUBGROUP_VOTE_EXTENSION_NAME "VK_EXT_shader_subgroup_vote"
+
+
+#define VK_NVX_device_generated_commands 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkObjectTableNVX)
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkIndirectCommandsLayoutNVX)
+
+#define VK_NVX_DEVICE_GENERATED_COMMANDS_SPEC_VERSION 3
+#define VK_NVX_DEVICE_GENERATED_COMMANDS_EXTENSION_NAME "VK_NVX_device_generated_commands"
+
+
+typedef enum VkIndirectCommandsTokenTypeNVX {
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX = 0,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_DESCRIPTOR_SET_NVX = 1,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_INDEX_BUFFER_NVX = 2,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_VERTEX_BUFFER_NVX = 3,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_PUSH_CONSTANT_NVX = 4,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED_NVX = 5,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX = 6,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX = 7,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_BEGIN_RANGE_NVX = VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_END_RANGE_NVX = VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX,
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_RANGE_SIZE_NVX = (VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX - VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX + 1),
+ VK_INDIRECT_COMMANDS_TOKEN_TYPE_MAX_ENUM_NVX = 0x7FFFFFFF
+} VkIndirectCommandsTokenTypeNVX;
+
+typedef enum VkObjectEntryTypeNVX {
+ VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX = 0,
+ VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX = 1,
+ VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX = 2,
+ VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX = 3,
+ VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX = 4,
+ VK_OBJECT_ENTRY_TYPE_BEGIN_RANGE_NVX = VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX,
+ VK_OBJECT_ENTRY_TYPE_END_RANGE_NVX = VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX,
+ VK_OBJECT_ENTRY_TYPE_RANGE_SIZE_NVX = (VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX - VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX + 1),
+ VK_OBJECT_ENTRY_TYPE_MAX_ENUM_NVX = 0x7FFFFFFF
+} VkObjectEntryTypeNVX;
+
+
+typedef enum VkIndirectCommandsLayoutUsageFlagBitsNVX {
+ VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX = 0x00000001,
+ VK_INDIRECT_COMMANDS_LAYOUT_USAGE_SPARSE_SEQUENCES_BIT_NVX = 0x00000002,
+ VK_INDIRECT_COMMANDS_LAYOUT_USAGE_EMPTY_EXECUTIONS_BIT_NVX = 0x00000004,
+ VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX = 0x00000008,
+ VK_INDIRECT_COMMANDS_LAYOUT_USAGE_FLAG_BITS_MAX_ENUM_NVX = 0x7FFFFFFF
+} VkIndirectCommandsLayoutUsageFlagBitsNVX;
+typedef VkFlags VkIndirectCommandsLayoutUsageFlagsNVX;
+
+typedef enum VkObjectEntryUsageFlagBitsNVX {
+ VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX = 0x00000001,
+ VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX = 0x00000002,
+ VK_OBJECT_ENTRY_USAGE_FLAG_BITS_MAX_ENUM_NVX = 0x7FFFFFFF
+} VkObjectEntryUsageFlagBitsNVX;
+typedef VkFlags VkObjectEntryUsageFlagsNVX;
+
+typedef struct VkDeviceGeneratedCommandsFeaturesNVX {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 computeBindingPointSupport;
+} VkDeviceGeneratedCommandsFeaturesNVX;
+
+typedef struct VkDeviceGeneratedCommandsLimitsNVX {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t maxIndirectCommandsLayoutTokenCount;
+ uint32_t maxObjectEntryCounts;
+ uint32_t minSequenceCountBufferOffsetAlignment;
+ uint32_t minSequenceIndexBufferOffsetAlignment;
+ uint32_t minCommandsTokenBufferOffsetAlignment;
+} VkDeviceGeneratedCommandsLimitsNVX;
+
+typedef struct VkIndirectCommandsTokenNVX {
+ VkIndirectCommandsTokenTypeNVX tokenType;
+ VkBuffer buffer;
+ VkDeviceSize offset;
+} VkIndirectCommandsTokenNVX;
+
+typedef struct VkIndirectCommandsLayoutTokenNVX {
+ VkIndirectCommandsTokenTypeNVX tokenType;
+ uint32_t bindingUnit;
+ uint32_t dynamicCount;
+ uint32_t divisor;
+} VkIndirectCommandsLayoutTokenNVX;
+
+typedef struct VkIndirectCommandsLayoutCreateInfoNVX {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineBindPoint pipelineBindPoint;
+ VkIndirectCommandsLayoutUsageFlagsNVX flags;
+ uint32_t tokenCount;
+ const VkIndirectCommandsLayoutTokenNVX* pTokens;
+} VkIndirectCommandsLayoutCreateInfoNVX;
+
+typedef struct VkCmdProcessCommandsInfoNVX {
+ VkStructureType sType;
+ const void* pNext;
+ VkObjectTableNVX objectTable;
+ VkIndirectCommandsLayoutNVX indirectCommandsLayout;
+ uint32_t indirectCommandsTokenCount;
+ const VkIndirectCommandsTokenNVX* pIndirectCommandsTokens;
+ uint32_t maxSequencesCount;
+ VkCommandBuffer targetCommandBuffer;
+ VkBuffer sequencesCountBuffer;
+ VkDeviceSize sequencesCountOffset;
+ VkBuffer sequencesIndexBuffer;
+ VkDeviceSize sequencesIndexOffset;
+} VkCmdProcessCommandsInfoNVX;
+
+typedef struct VkCmdReserveSpaceForCommandsInfoNVX {
+ VkStructureType sType;
+ const void* pNext;
+ VkObjectTableNVX objectTable;
+ VkIndirectCommandsLayoutNVX indirectCommandsLayout;
+ uint32_t maxSequencesCount;
+} VkCmdReserveSpaceForCommandsInfoNVX;
+
+typedef struct VkObjectTableCreateInfoNVX {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t objectCount;
+ const VkObjectEntryTypeNVX* pObjectEntryTypes;
+ const uint32_t* pObjectEntryCounts;
+ const VkObjectEntryUsageFlagsNVX* pObjectEntryUsageFlags;
+ uint32_t maxUniformBuffersPerDescriptor;
+ uint32_t maxStorageBuffersPerDescriptor;
+ uint32_t maxStorageImagesPerDescriptor;
+ uint32_t maxSampledImagesPerDescriptor;
+ uint32_t maxPipelineLayouts;
+} VkObjectTableCreateInfoNVX;
+
+typedef struct VkObjectTableEntryNVX {
+ VkObjectEntryTypeNVX type;
+ VkObjectEntryUsageFlagsNVX flags;
+} VkObjectTableEntryNVX;
+
+typedef struct VkObjectTablePipelineEntryNVX {
+ VkObjectEntryTypeNVX type;
+ VkObjectEntryUsageFlagsNVX flags;
+ VkPipeline pipeline;
+} VkObjectTablePipelineEntryNVX;
+
+typedef struct VkObjectTableDescriptorSetEntryNVX {
+ VkObjectEntryTypeNVX type;
+ VkObjectEntryUsageFlagsNVX flags;
+ VkPipelineLayout pipelineLayout;
+ VkDescriptorSet descriptorSet;
+} VkObjectTableDescriptorSetEntryNVX;
+
+typedef struct VkObjectTableVertexBufferEntryNVX {
+ VkObjectEntryTypeNVX type;
+ VkObjectEntryUsageFlagsNVX flags;
+ VkBuffer buffer;
+} VkObjectTableVertexBufferEntryNVX;
+
+typedef struct VkObjectTableIndexBufferEntryNVX {
+ VkObjectEntryTypeNVX type;
+ VkObjectEntryUsageFlagsNVX flags;
+ VkBuffer buffer;
+ VkIndexType indexType;
+} VkObjectTableIndexBufferEntryNVX;
+
+typedef struct VkObjectTablePushConstantEntryNVX {
+ VkObjectEntryTypeNVX type;
+ VkObjectEntryUsageFlagsNVX flags;
+ VkPipelineLayout pipelineLayout;
+ VkShaderStageFlags stageFlags;
+} VkObjectTablePushConstantEntryNVX;
+
+
+typedef void (VKAPI_PTR *PFN_vkCmdProcessCommandsNVX)(VkCommandBuffer commandBuffer, const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo);
+typedef void (VKAPI_PTR *PFN_vkCmdReserveSpaceForCommandsNVX)(VkCommandBuffer commandBuffer, const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateIndirectCommandsLayoutNVX)(VkDevice device, const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout);
+typedef void (VKAPI_PTR *PFN_vkDestroyIndirectCommandsLayoutNVX)(VkDevice device, VkIndirectCommandsLayoutNVX indirectCommandsLayout, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateObjectTableNVX)(VkDevice device, const VkObjectTableCreateInfoNVX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkObjectTableNVX* pObjectTable);
+typedef void (VKAPI_PTR *PFN_vkDestroyObjectTableNVX)(VkDevice device, VkObjectTableNVX objectTable, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkRegisterObjectsNVX)(VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectTableEntryNVX* const* ppObjectTableEntries, const uint32_t* pObjectIndices);
+typedef VkResult (VKAPI_PTR *PFN_vkUnregisterObjectsNVX)(VkDevice device, VkObjectTableNVX objectTable, uint32_t objectCount, const VkObjectEntryTypeNVX* pObjectEntryTypes, const uint32_t* pObjectIndices);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX)(VkPhysicalDevice physicalDevice, VkDeviceGeneratedCommandsFeaturesNVX* pFeatures, VkDeviceGeneratedCommandsLimitsNVX* pLimits);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdProcessCommandsNVX(
+ VkCommandBuffer commandBuffer,
+ const VkCmdProcessCommandsInfoNVX* pProcessCommandsInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdReserveSpaceForCommandsNVX(
+ VkCommandBuffer commandBuffer,
+ const VkCmdReserveSpaceForCommandsInfoNVX* pReserveSpaceInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateIndirectCommandsLayoutNVX(
+ VkDevice device,
+ const VkIndirectCommandsLayoutCreateInfoNVX* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkIndirectCommandsLayoutNVX* pIndirectCommandsLayout);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyIndirectCommandsLayoutNVX(
+ VkDevice device,
+ VkIndirectCommandsLayoutNVX indirectCommandsLayout,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateObjectTableNVX(
+ VkDevice device,
+ const VkObjectTableCreateInfoNVX* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkObjectTableNVX* pObjectTable);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyObjectTableNVX(
+ VkDevice device,
+ VkObjectTableNVX objectTable,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkRegisterObjectsNVX(
+ VkDevice device,
+ VkObjectTableNVX objectTable,
+ uint32_t objectCount,
+ const VkObjectTableEntryNVX* const* ppObjectTableEntries,
+ const uint32_t* pObjectIndices);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkUnregisterObjectsNVX(
+ VkDevice device,
+ VkObjectTableNVX objectTable,
+ uint32_t objectCount,
+ const VkObjectEntryTypeNVX* pObjectEntryTypes,
+ const uint32_t* pObjectIndices);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX(
+ VkPhysicalDevice physicalDevice,
+ VkDeviceGeneratedCommandsFeaturesNVX* pFeatures,
+ VkDeviceGeneratedCommandsLimitsNVX* pLimits);
+#endif
+
+#define VK_NV_clip_space_w_scaling 1
+#define VK_NV_CLIP_SPACE_W_SCALING_SPEC_VERSION 1
+#define VK_NV_CLIP_SPACE_W_SCALING_EXTENSION_NAME "VK_NV_clip_space_w_scaling"
+
+typedef struct VkViewportWScalingNV {
+ float xcoeff;
+ float ycoeff;
+} VkViewportWScalingNV;
+
+typedef struct VkPipelineViewportWScalingStateCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 viewportWScalingEnable;
+ uint32_t viewportCount;
+ const VkViewportWScalingNV* pViewportWScalings;
+} VkPipelineViewportWScalingStateCreateInfoNV;
+
+
+typedef void (VKAPI_PTR *PFN_vkCmdSetViewportWScalingNV)(VkCommandBuffer commandBuffer, uint32_t firstViewport, uint32_t viewportCount, const VkViewportWScalingNV* pViewportWScalings);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdSetViewportWScalingNV(
+ VkCommandBuffer commandBuffer,
+ uint32_t firstViewport,
+ uint32_t viewportCount,
+ const VkViewportWScalingNV* pViewportWScalings);
+#endif
+
+#define VK_EXT_direct_mode_display 1
+#define VK_EXT_DIRECT_MODE_DISPLAY_SPEC_VERSION 1
+#define VK_EXT_DIRECT_MODE_DISPLAY_EXTENSION_NAME "VK_EXT_direct_mode_display"
+
+typedef VkResult (VKAPI_PTR *PFN_vkReleaseDisplayEXT)(VkPhysicalDevice physicalDevice, VkDisplayKHR display);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkReleaseDisplayEXT(
+ VkPhysicalDevice physicalDevice,
+ VkDisplayKHR display);
+#endif
+
+#define VK_EXT_display_surface_counter 1
+#define VK_EXT_DISPLAY_SURFACE_COUNTER_SPEC_VERSION 1
+#define VK_EXT_DISPLAY_SURFACE_COUNTER_EXTENSION_NAME "VK_EXT_display_surface_counter"
+#define VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES2_EXT VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT
+
+
+typedef enum VkSurfaceCounterFlagBitsEXT {
+ VK_SURFACE_COUNTER_VBLANK_EXT = 0x00000001,
+ VK_SURFACE_COUNTER_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkSurfaceCounterFlagBitsEXT;
+typedef VkFlags VkSurfaceCounterFlagsEXT;
+
+typedef struct VkSurfaceCapabilities2EXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t minImageCount;
+ uint32_t maxImageCount;
+ VkExtent2D currentExtent;
+ VkExtent2D minImageExtent;
+ VkExtent2D maxImageExtent;
+ uint32_t maxImageArrayLayers;
+ VkSurfaceTransformFlagsKHR supportedTransforms;
+ VkSurfaceTransformFlagBitsKHR currentTransform;
+ VkCompositeAlphaFlagsKHR supportedCompositeAlpha;
+ VkImageUsageFlags supportedUsageFlags;
+ VkSurfaceCounterFlagsEXT supportedSurfaceCounters;
+} VkSurfaceCapabilities2EXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceSurfaceCapabilities2EXT)(VkPhysicalDevice physicalDevice, VkSurfaceKHR surface, VkSurfaceCapabilities2EXT* pSurfaceCapabilities);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceSurfaceCapabilities2EXT(
+ VkPhysicalDevice physicalDevice,
+ VkSurfaceKHR surface,
+ VkSurfaceCapabilities2EXT* pSurfaceCapabilities);
+#endif
+
+#define VK_EXT_display_control 1
+#define VK_EXT_DISPLAY_CONTROL_SPEC_VERSION 1
+#define VK_EXT_DISPLAY_CONTROL_EXTENSION_NAME "VK_EXT_display_control"
+
+
+typedef enum VkDisplayPowerStateEXT {
+ VK_DISPLAY_POWER_STATE_OFF_EXT = 0,
+ VK_DISPLAY_POWER_STATE_SUSPEND_EXT = 1,
+ VK_DISPLAY_POWER_STATE_ON_EXT = 2,
+ VK_DISPLAY_POWER_STATE_BEGIN_RANGE_EXT = VK_DISPLAY_POWER_STATE_OFF_EXT,
+ VK_DISPLAY_POWER_STATE_END_RANGE_EXT = VK_DISPLAY_POWER_STATE_ON_EXT,
+ VK_DISPLAY_POWER_STATE_RANGE_SIZE_EXT = (VK_DISPLAY_POWER_STATE_ON_EXT - VK_DISPLAY_POWER_STATE_OFF_EXT + 1),
+ VK_DISPLAY_POWER_STATE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDisplayPowerStateEXT;
+
+typedef enum VkDeviceEventTypeEXT {
+ VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT = 0,
+ VK_DEVICE_EVENT_TYPE_BEGIN_RANGE_EXT = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT,
+ VK_DEVICE_EVENT_TYPE_END_RANGE_EXT = VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT,
+ VK_DEVICE_EVENT_TYPE_RANGE_SIZE_EXT = (VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT - VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT + 1),
+ VK_DEVICE_EVENT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDeviceEventTypeEXT;
+
+typedef enum VkDisplayEventTypeEXT {
+ VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT = 0,
+ VK_DISPLAY_EVENT_TYPE_BEGIN_RANGE_EXT = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT,
+ VK_DISPLAY_EVENT_TYPE_END_RANGE_EXT = VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT,
+ VK_DISPLAY_EVENT_TYPE_RANGE_SIZE_EXT = (VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT - VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT + 1),
+ VK_DISPLAY_EVENT_TYPE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDisplayEventTypeEXT;
+
+typedef struct VkDisplayPowerInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDisplayPowerStateEXT powerState;
+} VkDisplayPowerInfoEXT;
+
+typedef struct VkDeviceEventInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceEventTypeEXT deviceEvent;
+} VkDeviceEventInfoEXT;
+
+typedef struct VkDisplayEventInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDisplayEventTypeEXT displayEvent;
+} VkDisplayEventInfoEXT;
+
+typedef struct VkSwapchainCounterCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkSurfaceCounterFlagsEXT surfaceCounters;
+} VkSwapchainCounterCreateInfoEXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkDisplayPowerControlEXT)(VkDevice device, VkDisplayKHR display, const VkDisplayPowerInfoEXT* pDisplayPowerInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkRegisterDeviceEventEXT)(VkDevice device, const VkDeviceEventInfoEXT* pDeviceEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence);
+typedef VkResult (VKAPI_PTR *PFN_vkRegisterDisplayEventEXT)(VkDevice device, VkDisplayKHR display, const VkDisplayEventInfoEXT* pDisplayEventInfo, const VkAllocationCallbacks* pAllocator, VkFence* pFence);
+typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainCounterEXT)(VkDevice device, VkSwapchainKHR swapchain, VkSurfaceCounterFlagBitsEXT counter, uint64_t* pCounterValue);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkDisplayPowerControlEXT(
+ VkDevice device,
+ VkDisplayKHR display,
+ const VkDisplayPowerInfoEXT* pDisplayPowerInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkRegisterDeviceEventEXT(
+ VkDevice device,
+ const VkDeviceEventInfoEXT* pDeviceEventInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkFence* pFence);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkRegisterDisplayEventEXT(
+ VkDevice device,
+ VkDisplayKHR display,
+ const VkDisplayEventInfoEXT* pDisplayEventInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkFence* pFence);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainCounterEXT(
+ VkDevice device,
+ VkSwapchainKHR swapchain,
+ VkSurfaceCounterFlagBitsEXT counter,
+ uint64_t* pCounterValue);
+#endif
+
+#define VK_GOOGLE_display_timing 1
+#define VK_GOOGLE_DISPLAY_TIMING_SPEC_VERSION 1
+#define VK_GOOGLE_DISPLAY_TIMING_EXTENSION_NAME "VK_GOOGLE_display_timing"
+
+typedef struct VkRefreshCycleDurationGOOGLE {
+ uint64_t refreshDuration;
+} VkRefreshCycleDurationGOOGLE;
+
+typedef struct VkPastPresentationTimingGOOGLE {
+ uint32_t presentID;
+ uint64_t desiredPresentTime;
+ uint64_t actualPresentTime;
+ uint64_t earliestPresentTime;
+ uint64_t presentMargin;
+} VkPastPresentationTimingGOOGLE;
+
+typedef struct VkPresentTimeGOOGLE {
+ uint32_t presentID;
+ uint64_t desiredPresentTime;
+} VkPresentTimeGOOGLE;
+
+typedef struct VkPresentTimesInfoGOOGLE {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t swapchainCount;
+ const VkPresentTimeGOOGLE* pTimes;
+} VkPresentTimesInfoGOOGLE;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetRefreshCycleDurationGOOGLE)(VkDevice device, VkSwapchainKHR swapchain, VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties);
+typedef VkResult (VKAPI_PTR *PFN_vkGetPastPresentationTimingGOOGLE)(VkDevice device, VkSwapchainKHR swapchain, uint32_t* pPresentationTimingCount, VkPastPresentationTimingGOOGLE* pPresentationTimings);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetRefreshCycleDurationGOOGLE(
+ VkDevice device,
+ VkSwapchainKHR swapchain,
+ VkRefreshCycleDurationGOOGLE* pDisplayTimingProperties);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetPastPresentationTimingGOOGLE(
+ VkDevice device,
+ VkSwapchainKHR swapchain,
+ uint32_t* pPresentationTimingCount,
+ VkPastPresentationTimingGOOGLE* pPresentationTimings);
+#endif
+
+#define VK_NV_sample_mask_override_coverage 1
+#define VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_SPEC_VERSION 1
+#define VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_EXTENSION_NAME "VK_NV_sample_mask_override_coverage"
+
+
+#define VK_NV_geometry_shader_passthrough 1
+#define VK_NV_GEOMETRY_SHADER_PASSTHROUGH_SPEC_VERSION 1
+#define VK_NV_GEOMETRY_SHADER_PASSTHROUGH_EXTENSION_NAME "VK_NV_geometry_shader_passthrough"
+
+
+#define VK_NV_viewport_array2 1
+#define VK_NV_VIEWPORT_ARRAY2_SPEC_VERSION 1
+#define VK_NV_VIEWPORT_ARRAY2_EXTENSION_NAME "VK_NV_viewport_array2"
+
+
+#define VK_NVX_multiview_per_view_attributes 1
+#define VK_NVX_MULTIVIEW_PER_VIEW_ATTRIBUTES_SPEC_VERSION 1
+#define VK_NVX_MULTIVIEW_PER_VIEW_ATTRIBUTES_EXTENSION_NAME "VK_NVX_multiview_per_view_attributes"
+
+typedef struct VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 perViewPositionAllComponents;
+} VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX;
+
+
+
+#define VK_NV_viewport_swizzle 1
+#define VK_NV_VIEWPORT_SWIZZLE_SPEC_VERSION 1
+#define VK_NV_VIEWPORT_SWIZZLE_EXTENSION_NAME "VK_NV_viewport_swizzle"
+
+
+typedef enum VkViewportCoordinateSwizzleNV {
+ VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV = 0,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_X_NV = 1,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Y_NV = 2,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Y_NV = 3,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Z_NV = 4,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Z_NV = 5,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_W_NV = 6,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV = 7,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_BEGIN_RANGE_NV = VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_END_RANGE_NV = VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV,
+ VK_VIEWPORT_COORDINATE_SWIZZLE_RANGE_SIZE_NV = (VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV - VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV + 1),
+ VK_VIEWPORT_COORDINATE_SWIZZLE_MAX_ENUM_NV = 0x7FFFFFFF
+} VkViewportCoordinateSwizzleNV;
+
+typedef VkFlags VkPipelineViewportSwizzleStateCreateFlagsNV;
+
+typedef struct VkViewportSwizzleNV {
+ VkViewportCoordinateSwizzleNV x;
+ VkViewportCoordinateSwizzleNV y;
+ VkViewportCoordinateSwizzleNV z;
+ VkViewportCoordinateSwizzleNV w;
+} VkViewportSwizzleNV;
+
+typedef struct VkPipelineViewportSwizzleStateCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineViewportSwizzleStateCreateFlagsNV flags;
+ uint32_t viewportCount;
+ const VkViewportSwizzleNV* pViewportSwizzles;
+} VkPipelineViewportSwizzleStateCreateInfoNV;
+
+
+
+#define VK_EXT_discard_rectangles 1
+#define VK_EXT_DISCARD_RECTANGLES_SPEC_VERSION 1
+#define VK_EXT_DISCARD_RECTANGLES_EXTENSION_NAME "VK_EXT_discard_rectangles"
+
+
+typedef enum VkDiscardRectangleModeEXT {
+ VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT = 0,
+ VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT = 1,
+ VK_DISCARD_RECTANGLE_MODE_BEGIN_RANGE_EXT = VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT,
+ VK_DISCARD_RECTANGLE_MODE_END_RANGE_EXT = VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT,
+ VK_DISCARD_RECTANGLE_MODE_RANGE_SIZE_EXT = (VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT - VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT + 1),
+ VK_DISCARD_RECTANGLE_MODE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDiscardRectangleModeEXT;
+
+typedef VkFlags VkPipelineDiscardRectangleStateCreateFlagsEXT;
+
+typedef struct VkPhysicalDeviceDiscardRectanglePropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxDiscardRectangles;
+} VkPhysicalDeviceDiscardRectanglePropertiesEXT;
+
+typedef struct VkPipelineDiscardRectangleStateCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineDiscardRectangleStateCreateFlagsEXT flags;
+ VkDiscardRectangleModeEXT discardRectangleMode;
+ uint32_t discardRectangleCount;
+ const VkRect2D* pDiscardRectangles;
+} VkPipelineDiscardRectangleStateCreateInfoEXT;
+
+
+typedef void (VKAPI_PTR *PFN_vkCmdSetDiscardRectangleEXT)(VkCommandBuffer commandBuffer, uint32_t firstDiscardRectangle, uint32_t discardRectangleCount, const VkRect2D* pDiscardRectangles);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdSetDiscardRectangleEXT(
+ VkCommandBuffer commandBuffer,
+ uint32_t firstDiscardRectangle,
+ uint32_t discardRectangleCount,
+ const VkRect2D* pDiscardRectangles);
+#endif
+
+#define VK_EXT_conservative_rasterization 1
+#define VK_EXT_CONSERVATIVE_RASTERIZATION_SPEC_VERSION 1
+#define VK_EXT_CONSERVATIVE_RASTERIZATION_EXTENSION_NAME "VK_EXT_conservative_rasterization"
+
+
+typedef enum VkConservativeRasterizationModeEXT {
+ VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT = 0,
+ VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT = 1,
+ VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT = 2,
+ VK_CONSERVATIVE_RASTERIZATION_MODE_BEGIN_RANGE_EXT = VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT,
+ VK_CONSERVATIVE_RASTERIZATION_MODE_END_RANGE_EXT = VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT,
+ VK_CONSERVATIVE_RASTERIZATION_MODE_RANGE_SIZE_EXT = (VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT - VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT + 1),
+ VK_CONSERVATIVE_RASTERIZATION_MODE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkConservativeRasterizationModeEXT;
+
+typedef VkFlags VkPipelineRasterizationConservativeStateCreateFlagsEXT;
+
+typedef struct VkPhysicalDeviceConservativeRasterizationPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ float primitiveOverestimationSize;
+ float maxExtraPrimitiveOverestimationSize;
+ float extraPrimitiveOverestimationSizeGranularity;
+ VkBool32 primitiveUnderestimation;
+ VkBool32 conservativePointAndLineRasterization;
+ VkBool32 degenerateTrianglesRasterized;
+ VkBool32 degenerateLinesRasterized;
+ VkBool32 fullyCoveredFragmentShaderInputVariable;
+ VkBool32 conservativeRasterizationPostDepthCoverage;
+} VkPhysicalDeviceConservativeRasterizationPropertiesEXT;
+
+typedef struct VkPipelineRasterizationConservativeStateCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineRasterizationConservativeStateCreateFlagsEXT flags;
+ VkConservativeRasterizationModeEXT conservativeRasterizationMode;
+ float extraPrimitiveOverestimationSize;
+} VkPipelineRasterizationConservativeStateCreateInfoEXT;
+
+
+
+#define VK_EXT_swapchain_colorspace 1
+#define VK_EXT_SWAPCHAIN_COLOR_SPACE_SPEC_VERSION 3
+#define VK_EXT_SWAPCHAIN_COLOR_SPACE_EXTENSION_NAME "VK_EXT_swapchain_colorspace"
+
+
+#define VK_EXT_hdr_metadata 1
+#define VK_EXT_HDR_METADATA_SPEC_VERSION 1
+#define VK_EXT_HDR_METADATA_EXTENSION_NAME "VK_EXT_hdr_metadata"
+
+typedef struct VkXYColorEXT {
+ float x;
+ float y;
+} VkXYColorEXT;
+
+typedef struct VkHdrMetadataEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkXYColorEXT displayPrimaryRed;
+ VkXYColorEXT displayPrimaryGreen;
+ VkXYColorEXT displayPrimaryBlue;
+ VkXYColorEXT whitePoint;
+ float maxLuminance;
+ float minLuminance;
+ float maxContentLightLevel;
+ float maxFrameAverageLightLevel;
+} VkHdrMetadataEXT;
+
+
+typedef void (VKAPI_PTR *PFN_vkSetHdrMetadataEXT)(VkDevice device, uint32_t swapchainCount, const VkSwapchainKHR* pSwapchains, const VkHdrMetadataEXT* pMetadata);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkSetHdrMetadataEXT(
+ VkDevice device,
+ uint32_t swapchainCount,
+ const VkSwapchainKHR* pSwapchains,
+ const VkHdrMetadataEXT* pMetadata);
+#endif
+
+#define VK_EXT_external_memory_dma_buf 1
+#define VK_EXT_EXTERNAL_MEMORY_DMA_BUF_SPEC_VERSION 1
+#define VK_EXT_EXTERNAL_MEMORY_DMA_BUF_EXTENSION_NAME "VK_EXT_external_memory_dma_buf"
+
+
+#define VK_EXT_queue_family_foreign 1
+#define VK_EXT_QUEUE_FAMILY_FOREIGN_SPEC_VERSION 1
+#define VK_EXT_QUEUE_FAMILY_FOREIGN_EXTENSION_NAME "VK_EXT_queue_family_foreign"
+#define VK_QUEUE_FAMILY_FOREIGN_EXT (~0U-2)
+
+
+#define VK_EXT_debug_utils 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkDebugUtilsMessengerEXT)
+
+#define VK_EXT_DEBUG_UTILS_SPEC_VERSION 1
+#define VK_EXT_DEBUG_UTILS_EXTENSION_NAME "VK_EXT_debug_utils"
+
+typedef VkFlags VkDebugUtilsMessengerCallbackDataFlagsEXT;
+typedef VkFlags VkDebugUtilsMessengerCreateFlagsEXT;
+
+typedef enum VkDebugUtilsMessageSeverityFlagBitsEXT {
+ VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT = 0x00000001,
+ VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT = 0x00000010,
+ VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT = 0x00000100,
+ VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT = 0x00001000,
+ VK_DEBUG_UTILS_MESSAGE_SEVERITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDebugUtilsMessageSeverityFlagBitsEXT;
+typedef VkFlags VkDebugUtilsMessageSeverityFlagsEXT;
+
+typedef enum VkDebugUtilsMessageTypeFlagBitsEXT {
+ VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT = 0x00000001,
+ VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT = 0x00000002,
+ VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT = 0x00000004,
+ VK_DEBUG_UTILS_MESSAGE_TYPE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDebugUtilsMessageTypeFlagBitsEXT;
+typedef VkFlags VkDebugUtilsMessageTypeFlagsEXT;
+
+typedef struct VkDebugUtilsObjectNameInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkObjectType objectType;
+ uint64_t objectHandle;
+ const char* pObjectName;
+} VkDebugUtilsObjectNameInfoEXT;
+
+typedef struct VkDebugUtilsObjectTagInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkObjectType objectType;
+ uint64_t objectHandle;
+ uint64_t tagName;
+ size_t tagSize;
+ const void* pTag;
+} VkDebugUtilsObjectTagInfoEXT;
+
+typedef struct VkDebugUtilsLabelEXT {
+ VkStructureType sType;
+ const void* pNext;
+ const char* pLabelName;
+ float color[4];
+} VkDebugUtilsLabelEXT;
+
+typedef struct VkDebugUtilsMessengerCallbackDataEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDebugUtilsMessengerCallbackDataFlagsEXT flags;
+ const char* pMessageIdName;
+ int32_t messageIdNumber;
+ const char* pMessage;
+ uint32_t queueLabelCount;
+ VkDebugUtilsLabelEXT* pQueueLabels;
+ uint32_t cmdBufLabelCount;
+ VkDebugUtilsLabelEXT* pCmdBufLabels;
+ uint32_t objectCount;
+ VkDebugUtilsObjectNameInfoEXT* pObjects;
+} VkDebugUtilsMessengerCallbackDataEXT;
+
+typedef VkBool32 (VKAPI_PTR *PFN_vkDebugUtilsMessengerCallbackEXT)(
+ VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
+ VkDebugUtilsMessageTypeFlagsEXT messageType,
+ const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData,
+ void* pUserData);
+
+typedef struct VkDebugUtilsMessengerCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkDebugUtilsMessengerCreateFlagsEXT flags;
+ VkDebugUtilsMessageSeverityFlagsEXT messageSeverity;
+ VkDebugUtilsMessageTypeFlagsEXT messageType;
+ PFN_vkDebugUtilsMessengerCallbackEXT pfnUserCallback;
+ void* pUserData;
+} VkDebugUtilsMessengerCreateInfoEXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkSetDebugUtilsObjectNameEXT)(VkDevice device, const VkDebugUtilsObjectNameInfoEXT* pNameInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkSetDebugUtilsObjectTagEXT)(VkDevice device, const VkDebugUtilsObjectTagInfoEXT* pTagInfo);
+typedef void (VKAPI_PTR *PFN_vkQueueBeginDebugUtilsLabelEXT)(VkQueue queue, const VkDebugUtilsLabelEXT* pLabelInfo);
+typedef void (VKAPI_PTR *PFN_vkQueueEndDebugUtilsLabelEXT)(VkQueue queue);
+typedef void (VKAPI_PTR *PFN_vkQueueInsertDebugUtilsLabelEXT)(VkQueue queue, const VkDebugUtilsLabelEXT* pLabelInfo);
+typedef void (VKAPI_PTR *PFN_vkCmdBeginDebugUtilsLabelEXT)(VkCommandBuffer commandBuffer, const VkDebugUtilsLabelEXT* pLabelInfo);
+typedef void (VKAPI_PTR *PFN_vkCmdEndDebugUtilsLabelEXT)(VkCommandBuffer commandBuffer);
+typedef void (VKAPI_PTR *PFN_vkCmdInsertDebugUtilsLabelEXT)(VkCommandBuffer commandBuffer, const VkDebugUtilsLabelEXT* pLabelInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkCreateDebugUtilsMessengerEXT)(VkInstance instance, const VkDebugUtilsMessengerCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkDebugUtilsMessengerEXT* pMessenger);
+typedef void (VKAPI_PTR *PFN_vkDestroyDebugUtilsMessengerEXT)(VkInstance instance, VkDebugUtilsMessengerEXT messenger, const VkAllocationCallbacks* pAllocator);
+typedef void (VKAPI_PTR *PFN_vkSubmitDebugUtilsMessageEXT)(VkInstance instance, VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity, VkDebugUtilsMessageTypeFlagsEXT messageTypes, const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkSetDebugUtilsObjectNameEXT(
+ VkDevice device,
+ const VkDebugUtilsObjectNameInfoEXT* pNameInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkSetDebugUtilsObjectTagEXT(
+ VkDevice device,
+ const VkDebugUtilsObjectTagInfoEXT* pTagInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkQueueBeginDebugUtilsLabelEXT(
+ VkQueue queue,
+ const VkDebugUtilsLabelEXT* pLabelInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkQueueEndDebugUtilsLabelEXT(
+ VkQueue queue);
+
+VKAPI_ATTR void VKAPI_CALL vkQueueInsertDebugUtilsLabelEXT(
+ VkQueue queue,
+ const VkDebugUtilsLabelEXT* pLabelInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdBeginDebugUtilsLabelEXT(
+ VkCommandBuffer commandBuffer,
+ const VkDebugUtilsLabelEXT* pLabelInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdEndDebugUtilsLabelEXT(
+ VkCommandBuffer commandBuffer);
+
+VKAPI_ATTR void VKAPI_CALL vkCmdInsertDebugUtilsLabelEXT(
+ VkCommandBuffer commandBuffer,
+ const VkDebugUtilsLabelEXT* pLabelInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateDebugUtilsMessengerEXT(
+ VkInstance instance,
+ const VkDebugUtilsMessengerCreateInfoEXT* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkDebugUtilsMessengerEXT* pMessenger);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyDebugUtilsMessengerEXT(
+ VkInstance instance,
+ VkDebugUtilsMessengerEXT messenger,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR void VKAPI_CALL vkSubmitDebugUtilsMessageEXT(
+ VkInstance instance,
+ VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
+ VkDebugUtilsMessageTypeFlagsEXT messageTypes,
+ const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData);
+#endif
+
+#define VK_EXT_sampler_filter_minmax 1
+#define VK_EXT_SAMPLER_FILTER_MINMAX_SPEC_VERSION 1
+#define VK_EXT_SAMPLER_FILTER_MINMAX_EXTENSION_NAME "VK_EXT_sampler_filter_minmax"
+
+
+typedef enum VkSamplerReductionModeEXT {
+ VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT = 0,
+ VK_SAMPLER_REDUCTION_MODE_MIN_EXT = 1,
+ VK_SAMPLER_REDUCTION_MODE_MAX_EXT = 2,
+ VK_SAMPLER_REDUCTION_MODE_BEGIN_RANGE_EXT = VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT,
+ VK_SAMPLER_REDUCTION_MODE_END_RANGE_EXT = VK_SAMPLER_REDUCTION_MODE_MAX_EXT,
+ VK_SAMPLER_REDUCTION_MODE_RANGE_SIZE_EXT = (VK_SAMPLER_REDUCTION_MODE_MAX_EXT - VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT + 1),
+ VK_SAMPLER_REDUCTION_MODE_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkSamplerReductionModeEXT;
+
+typedef struct VkSamplerReductionModeCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkSamplerReductionModeEXT reductionMode;
+} VkSamplerReductionModeCreateInfoEXT;
+
+typedef struct VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 filterMinmaxSingleComponentFormats;
+ VkBool32 filterMinmaxImageComponentMapping;
+} VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT;
+
+
+
+#define VK_AMD_gpu_shader_int16 1
+#define VK_AMD_GPU_SHADER_INT16_SPEC_VERSION 1
+#define VK_AMD_GPU_SHADER_INT16_EXTENSION_NAME "VK_AMD_gpu_shader_int16"
+
+
+#define VK_AMD_mixed_attachment_samples 1
+#define VK_AMD_MIXED_ATTACHMENT_SAMPLES_SPEC_VERSION 1
+#define VK_AMD_MIXED_ATTACHMENT_SAMPLES_EXTENSION_NAME "VK_AMD_mixed_attachment_samples"
+
+
+#define VK_AMD_shader_fragment_mask 1
+#define VK_AMD_SHADER_FRAGMENT_MASK_SPEC_VERSION 1
+#define VK_AMD_SHADER_FRAGMENT_MASK_EXTENSION_NAME "VK_AMD_shader_fragment_mask"
+
+
+#define VK_EXT_shader_stencil_export 1
+#define VK_EXT_SHADER_STENCIL_EXPORT_SPEC_VERSION 1
+#define VK_EXT_SHADER_STENCIL_EXPORT_EXTENSION_NAME "VK_EXT_shader_stencil_export"
+
+
+#define VK_EXT_sample_locations 1
+#define VK_EXT_SAMPLE_LOCATIONS_SPEC_VERSION 1
+#define VK_EXT_SAMPLE_LOCATIONS_EXTENSION_NAME "VK_EXT_sample_locations"
+
+typedef struct VkSampleLocationEXT {
+ float x;
+ float y;
+} VkSampleLocationEXT;
+
+typedef struct VkSampleLocationsInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkSampleCountFlagBits sampleLocationsPerPixel;
+ VkExtent2D sampleLocationGridSize;
+ uint32_t sampleLocationsCount;
+ const VkSampleLocationEXT* pSampleLocations;
+} VkSampleLocationsInfoEXT;
+
+typedef struct VkAttachmentSampleLocationsEXT {
+ uint32_t attachmentIndex;
+ VkSampleLocationsInfoEXT sampleLocationsInfo;
+} VkAttachmentSampleLocationsEXT;
+
+typedef struct VkSubpassSampleLocationsEXT {
+ uint32_t subpassIndex;
+ VkSampleLocationsInfoEXT sampleLocationsInfo;
+} VkSubpassSampleLocationsEXT;
+
+typedef struct VkRenderPassSampleLocationsBeginInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t attachmentInitialSampleLocationsCount;
+ const VkAttachmentSampleLocationsEXT* pAttachmentInitialSampleLocations;
+ uint32_t postSubpassSampleLocationsCount;
+ const VkSubpassSampleLocationsEXT* pPostSubpassSampleLocations;
+} VkRenderPassSampleLocationsBeginInfoEXT;
+
+typedef struct VkPipelineSampleLocationsStateCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 sampleLocationsEnable;
+ VkSampleLocationsInfoEXT sampleLocationsInfo;
+} VkPipelineSampleLocationsStateCreateInfoEXT;
+
+typedef struct VkPhysicalDeviceSampleLocationsPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ VkSampleCountFlags sampleLocationSampleCounts;
+ VkExtent2D maxSampleLocationGridSize;
+ float sampleLocationCoordinateRange[2];
+ uint32_t sampleLocationSubPixelBits;
+ VkBool32 variableSampleLocations;
+} VkPhysicalDeviceSampleLocationsPropertiesEXT;
+
+typedef struct VkMultisamplePropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ VkExtent2D maxSampleLocationGridSize;
+} VkMultisamplePropertiesEXT;
+
+
+typedef void (VKAPI_PTR *PFN_vkCmdSetSampleLocationsEXT)(VkCommandBuffer commandBuffer, const VkSampleLocationsInfoEXT* pSampleLocationsInfo);
+typedef void (VKAPI_PTR *PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT)(VkPhysicalDevice physicalDevice, VkSampleCountFlagBits samples, VkMultisamplePropertiesEXT* pMultisampleProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdSetSampleLocationsEXT(
+ VkCommandBuffer commandBuffer,
+ const VkSampleLocationsInfoEXT* pSampleLocationsInfo);
+
+VKAPI_ATTR void VKAPI_CALL vkGetPhysicalDeviceMultisamplePropertiesEXT(
+ VkPhysicalDevice physicalDevice,
+ VkSampleCountFlagBits samples,
+ VkMultisamplePropertiesEXT* pMultisampleProperties);
+#endif
+
+#define VK_EXT_blend_operation_advanced 1
+#define VK_EXT_BLEND_OPERATION_ADVANCED_SPEC_VERSION 2
+#define VK_EXT_BLEND_OPERATION_ADVANCED_EXTENSION_NAME "VK_EXT_blend_operation_advanced"
+
+
+typedef enum VkBlendOverlapEXT {
+ VK_BLEND_OVERLAP_UNCORRELATED_EXT = 0,
+ VK_BLEND_OVERLAP_DISJOINT_EXT = 1,
+ VK_BLEND_OVERLAP_CONJOINT_EXT = 2,
+ VK_BLEND_OVERLAP_BEGIN_RANGE_EXT = VK_BLEND_OVERLAP_UNCORRELATED_EXT,
+ VK_BLEND_OVERLAP_END_RANGE_EXT = VK_BLEND_OVERLAP_CONJOINT_EXT,
+ VK_BLEND_OVERLAP_RANGE_SIZE_EXT = (VK_BLEND_OVERLAP_CONJOINT_EXT - VK_BLEND_OVERLAP_UNCORRELATED_EXT + 1),
+ VK_BLEND_OVERLAP_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkBlendOverlapEXT;
+
+typedef struct VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 advancedBlendCoherentOperations;
+} VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT;
+
+typedef struct VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t advancedBlendMaxColorAttachments;
+ VkBool32 advancedBlendIndependentBlend;
+ VkBool32 advancedBlendNonPremultipliedSrcColor;
+ VkBool32 advancedBlendNonPremultipliedDstColor;
+ VkBool32 advancedBlendCorrelatedOverlap;
+ VkBool32 advancedBlendAllOperations;
+} VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT;
+
+typedef struct VkPipelineColorBlendAdvancedStateCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkBool32 srcPremultiplied;
+ VkBool32 dstPremultiplied;
+ VkBlendOverlapEXT blendOverlap;
+} VkPipelineColorBlendAdvancedStateCreateInfoEXT;
+
+
+
+#define VK_NV_fragment_coverage_to_color 1
+#define VK_NV_FRAGMENT_COVERAGE_TO_COLOR_SPEC_VERSION 1
+#define VK_NV_FRAGMENT_COVERAGE_TO_COLOR_EXTENSION_NAME "VK_NV_fragment_coverage_to_color"
+
+typedef VkFlags VkPipelineCoverageToColorStateCreateFlagsNV;
+
+typedef struct VkPipelineCoverageToColorStateCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineCoverageToColorStateCreateFlagsNV flags;
+ VkBool32 coverageToColorEnable;
+ uint32_t coverageToColorLocation;
+} VkPipelineCoverageToColorStateCreateInfoNV;
+
+
+
+#define VK_NV_framebuffer_mixed_samples 1
+#define VK_NV_FRAMEBUFFER_MIXED_SAMPLES_SPEC_VERSION 1
+#define VK_NV_FRAMEBUFFER_MIXED_SAMPLES_EXTENSION_NAME "VK_NV_framebuffer_mixed_samples"
+
+
+typedef enum VkCoverageModulationModeNV {
+ VK_COVERAGE_MODULATION_MODE_NONE_NV = 0,
+ VK_COVERAGE_MODULATION_MODE_RGB_NV = 1,
+ VK_COVERAGE_MODULATION_MODE_ALPHA_NV = 2,
+ VK_COVERAGE_MODULATION_MODE_RGBA_NV = 3,
+ VK_COVERAGE_MODULATION_MODE_BEGIN_RANGE_NV = VK_COVERAGE_MODULATION_MODE_NONE_NV,
+ VK_COVERAGE_MODULATION_MODE_END_RANGE_NV = VK_COVERAGE_MODULATION_MODE_RGBA_NV,
+ VK_COVERAGE_MODULATION_MODE_RANGE_SIZE_NV = (VK_COVERAGE_MODULATION_MODE_RGBA_NV - VK_COVERAGE_MODULATION_MODE_NONE_NV + 1),
+ VK_COVERAGE_MODULATION_MODE_MAX_ENUM_NV = 0x7FFFFFFF
+} VkCoverageModulationModeNV;
+
+typedef VkFlags VkPipelineCoverageModulationStateCreateFlagsNV;
+
+typedef struct VkPipelineCoverageModulationStateCreateInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkPipelineCoverageModulationStateCreateFlagsNV flags;
+ VkCoverageModulationModeNV coverageModulationMode;
+ VkBool32 coverageModulationTableEnable;
+ uint32_t coverageModulationTableCount;
+ const float* pCoverageModulationTable;
+} VkPipelineCoverageModulationStateCreateInfoNV;
+
+
+
+#define VK_NV_fill_rectangle 1
+#define VK_NV_FILL_RECTANGLE_SPEC_VERSION 1
+#define VK_NV_FILL_RECTANGLE_EXTENSION_NAME "VK_NV_fill_rectangle"
+
+
+#define VK_EXT_post_depth_coverage 1
+#define VK_EXT_POST_DEPTH_COVERAGE_SPEC_VERSION 1
+#define VK_EXT_POST_DEPTH_COVERAGE_EXTENSION_NAME "VK_EXT_post_depth_coverage"
+
+
+#define VK_EXT_validation_cache 1
+VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkValidationCacheEXT)
+
+#define VK_EXT_VALIDATION_CACHE_SPEC_VERSION 1
+#define VK_EXT_VALIDATION_CACHE_EXTENSION_NAME "VK_EXT_validation_cache"
+#define VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT
+
+
+typedef enum VkValidationCacheHeaderVersionEXT {
+ VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT = 1,
+ VK_VALIDATION_CACHE_HEADER_VERSION_BEGIN_RANGE_EXT = VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT,
+ VK_VALIDATION_CACHE_HEADER_VERSION_END_RANGE_EXT = VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT,
+ VK_VALIDATION_CACHE_HEADER_VERSION_RANGE_SIZE_EXT = (VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT - VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT + 1),
+ VK_VALIDATION_CACHE_HEADER_VERSION_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkValidationCacheHeaderVersionEXT;
+
+typedef VkFlags VkValidationCacheCreateFlagsEXT;
+
+typedef struct VkValidationCacheCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkValidationCacheCreateFlagsEXT flags;
+ size_t initialDataSize;
+ const void* pInitialData;
+} VkValidationCacheCreateInfoEXT;
+
+typedef struct VkShaderModuleValidationCacheCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkValidationCacheEXT validationCache;
+} VkShaderModuleValidationCacheCreateInfoEXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateValidationCacheEXT)(VkDevice device, const VkValidationCacheCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkValidationCacheEXT* pValidationCache);
+typedef void (VKAPI_PTR *PFN_vkDestroyValidationCacheEXT)(VkDevice device, VkValidationCacheEXT validationCache, const VkAllocationCallbacks* pAllocator);
+typedef VkResult (VKAPI_PTR *PFN_vkMergeValidationCachesEXT)(VkDevice device, VkValidationCacheEXT dstCache, uint32_t srcCacheCount, const VkValidationCacheEXT* pSrcCaches);
+typedef VkResult (VKAPI_PTR *PFN_vkGetValidationCacheDataEXT)(VkDevice device, VkValidationCacheEXT validationCache, size_t* pDataSize, void* pData);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateValidationCacheEXT(
+ VkDevice device,
+ const VkValidationCacheCreateInfoEXT* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkValidationCacheEXT* pValidationCache);
+
+VKAPI_ATTR void VKAPI_CALL vkDestroyValidationCacheEXT(
+ VkDevice device,
+ VkValidationCacheEXT validationCache,
+ const VkAllocationCallbacks* pAllocator);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkMergeValidationCachesEXT(
+ VkDevice device,
+ VkValidationCacheEXT dstCache,
+ uint32_t srcCacheCount,
+ const VkValidationCacheEXT* pSrcCaches);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetValidationCacheDataEXT(
+ VkDevice device,
+ VkValidationCacheEXT validationCache,
+ size_t* pDataSize,
+ void* pData);
+#endif
+
+#define VK_EXT_descriptor_indexing 1
+#define VK_EXT_DESCRIPTOR_INDEXING_SPEC_VERSION 2
+#define VK_EXT_DESCRIPTOR_INDEXING_EXTENSION_NAME "VK_EXT_descriptor_indexing"
+
+
+typedef enum VkDescriptorBindingFlagBitsEXT {
+ VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT = 0x00000001,
+ VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT = 0x00000002,
+ VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT = 0x00000004,
+ VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT = 0x00000008,
+ VK_DESCRIPTOR_BINDING_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkDescriptorBindingFlagBitsEXT;
+typedef VkFlags VkDescriptorBindingFlagsEXT;
+
+typedef struct VkDescriptorSetLayoutBindingFlagsCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t bindingCount;
+ const VkDescriptorBindingFlagsEXT* pBindingFlags;
+} VkDescriptorSetLayoutBindingFlagsCreateInfoEXT;
+
+typedef struct VkPhysicalDeviceDescriptorIndexingFeaturesEXT {
+ VkStructureType sType;
+ void* pNext;
+ VkBool32 shaderInputAttachmentArrayDynamicIndexing;
+ VkBool32 shaderUniformTexelBufferArrayDynamicIndexing;
+ VkBool32 shaderStorageTexelBufferArrayDynamicIndexing;
+ VkBool32 shaderUniformBufferArrayNonUniformIndexing;
+ VkBool32 shaderSampledImageArrayNonUniformIndexing;
+ VkBool32 shaderStorageBufferArrayNonUniformIndexing;
+ VkBool32 shaderStorageImageArrayNonUniformIndexing;
+ VkBool32 shaderInputAttachmentArrayNonUniformIndexing;
+ VkBool32 shaderUniformTexelBufferArrayNonUniformIndexing;
+ VkBool32 shaderStorageTexelBufferArrayNonUniformIndexing;
+ VkBool32 descriptorBindingUniformBufferUpdateAfterBind;
+ VkBool32 descriptorBindingSampledImageUpdateAfterBind;
+ VkBool32 descriptorBindingStorageImageUpdateAfterBind;
+ VkBool32 descriptorBindingStorageBufferUpdateAfterBind;
+ VkBool32 descriptorBindingUniformTexelBufferUpdateAfterBind;
+ VkBool32 descriptorBindingStorageTexelBufferUpdateAfterBind;
+ VkBool32 descriptorBindingUpdateUnusedWhilePending;
+ VkBool32 descriptorBindingPartiallyBound;
+ VkBool32 descriptorBindingVariableDescriptorCount;
+ VkBool32 runtimeDescriptorArray;
+} VkPhysicalDeviceDescriptorIndexingFeaturesEXT;
+
+typedef struct VkPhysicalDeviceDescriptorIndexingPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxUpdateAfterBindDescriptorsInAllPools;
+ VkBool32 shaderUniformBufferArrayNonUniformIndexingNative;
+ VkBool32 shaderSampledImageArrayNonUniformIndexingNative;
+ VkBool32 shaderStorageBufferArrayNonUniformIndexingNative;
+ VkBool32 shaderStorageImageArrayNonUniformIndexingNative;
+ VkBool32 shaderInputAttachmentArrayNonUniformIndexingNative;
+ VkBool32 robustBufferAccessUpdateAfterBind;
+ VkBool32 quadDivergentImplicitLod;
+ uint32_t maxPerStageDescriptorUpdateAfterBindSamplers;
+ uint32_t maxPerStageDescriptorUpdateAfterBindUniformBuffers;
+ uint32_t maxPerStageDescriptorUpdateAfterBindStorageBuffers;
+ uint32_t maxPerStageDescriptorUpdateAfterBindSampledImages;
+ uint32_t maxPerStageDescriptorUpdateAfterBindStorageImages;
+ uint32_t maxPerStageDescriptorUpdateAfterBindInputAttachments;
+ uint32_t maxPerStageUpdateAfterBindResources;
+ uint32_t maxDescriptorSetUpdateAfterBindSamplers;
+ uint32_t maxDescriptorSetUpdateAfterBindUniformBuffers;
+ uint32_t maxDescriptorSetUpdateAfterBindUniformBuffersDynamic;
+ uint32_t maxDescriptorSetUpdateAfterBindStorageBuffers;
+ uint32_t maxDescriptorSetUpdateAfterBindStorageBuffersDynamic;
+ uint32_t maxDescriptorSetUpdateAfterBindSampledImages;
+ uint32_t maxDescriptorSetUpdateAfterBindStorageImages;
+ uint32_t maxDescriptorSetUpdateAfterBindInputAttachments;
+} VkPhysicalDeviceDescriptorIndexingPropertiesEXT;
+
+typedef struct VkDescriptorSetVariableDescriptorCountAllocateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t descriptorSetCount;
+ const uint32_t* pDescriptorCounts;
+} VkDescriptorSetVariableDescriptorCountAllocateInfoEXT;
+
+typedef struct VkDescriptorSetVariableDescriptorCountLayoutSupportEXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxVariableDescriptorCount;
+} VkDescriptorSetVariableDescriptorCountLayoutSupportEXT;
+
+
+
+#define VK_EXT_shader_viewport_index_layer 1
+#define VK_EXT_SHADER_VIEWPORT_INDEX_LAYER_SPEC_VERSION 1
+#define VK_EXT_SHADER_VIEWPORT_INDEX_LAYER_EXTENSION_NAME "VK_EXT_shader_viewport_index_layer"
+
+
+#define VK_EXT_global_priority 1
+#define VK_EXT_GLOBAL_PRIORITY_SPEC_VERSION 2
+#define VK_EXT_GLOBAL_PRIORITY_EXTENSION_NAME "VK_EXT_global_priority"
+
+
+typedef enum VkQueueGlobalPriorityEXT {
+ VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT = 128,
+ VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT = 256,
+ VK_QUEUE_GLOBAL_PRIORITY_HIGH_EXT = 512,
+ VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT = 1024,
+ VK_QUEUE_GLOBAL_PRIORITY_BEGIN_RANGE_EXT = VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT,
+ VK_QUEUE_GLOBAL_PRIORITY_END_RANGE_EXT = VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT,
+ VK_QUEUE_GLOBAL_PRIORITY_RANGE_SIZE_EXT = (VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT - VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT + 1),
+ VK_QUEUE_GLOBAL_PRIORITY_MAX_ENUM_EXT = 0x7FFFFFFF
+} VkQueueGlobalPriorityEXT;
+
+typedef struct VkDeviceQueueGlobalPriorityCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkQueueGlobalPriorityEXT globalPriority;
+} VkDeviceQueueGlobalPriorityCreateInfoEXT;
+
+
+
+#define VK_EXT_external_memory_host 1
+#define VK_EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION 1
+#define VK_EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME "VK_EXT_external_memory_host"
+
+typedef struct VkImportMemoryHostPointerInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+ void* pHostPointer;
+} VkImportMemoryHostPointerInfoEXT;
+
+typedef struct VkMemoryHostPointerPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t memoryTypeBits;
+} VkMemoryHostPointerPropertiesEXT;
+
+typedef struct VkPhysicalDeviceExternalMemoryHostPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ VkDeviceSize minImportedHostPointerAlignment;
+} VkPhysicalDeviceExternalMemoryHostPropertiesEXT;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryHostPointerPropertiesEXT)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, const void* pHostPointer, VkMemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryHostPointerPropertiesEXT(
+ VkDevice device,
+ VkExternalMemoryHandleTypeFlagBits handleType,
+ const void* pHostPointer,
+ VkMemoryHostPointerPropertiesEXT* pMemoryHostPointerProperties);
+#endif
+
+#define VK_AMD_buffer_marker 1
+#define VK_AMD_BUFFER_MARKER_SPEC_VERSION 1
+#define VK_AMD_BUFFER_MARKER_EXTENSION_NAME "VK_AMD_buffer_marker"
+
+typedef void (VKAPI_PTR *PFN_vkCmdWriteBufferMarkerAMD)(VkCommandBuffer commandBuffer, VkPipelineStageFlagBits pipelineStage, VkBuffer dstBuffer, VkDeviceSize dstOffset, uint32_t marker);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR void VKAPI_CALL vkCmdWriteBufferMarkerAMD(
+ VkCommandBuffer commandBuffer,
+ VkPipelineStageFlagBits pipelineStage,
+ VkBuffer dstBuffer,
+ VkDeviceSize dstOffset,
+ uint32_t marker);
+#endif
+
+#define VK_AMD_shader_core_properties 1
+#define VK_AMD_SHADER_CORE_PROPERTIES_SPEC_VERSION 1
+#define VK_AMD_SHADER_CORE_PROPERTIES_EXTENSION_NAME "VK_AMD_shader_core_properties"
+
+typedef struct VkPhysicalDeviceShaderCorePropertiesAMD {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t shaderEngineCount;
+ uint32_t shaderArraysPerEngineCount;
+ uint32_t computeUnitsPerShaderArray;
+ uint32_t simdPerComputeUnit;
+ uint32_t wavefrontsPerSimd;
+ uint32_t wavefrontSize;
+ uint32_t sgprsPerSimd;
+ uint32_t minSgprAllocation;
+ uint32_t maxSgprAllocation;
+ uint32_t sgprAllocationGranularity;
+ uint32_t vgprsPerSimd;
+ uint32_t minVgprAllocation;
+ uint32_t maxVgprAllocation;
+ uint32_t vgprAllocationGranularity;
+} VkPhysicalDeviceShaderCorePropertiesAMD;
+
+
+
+#define VK_EXT_vertex_attribute_divisor 1
+#define VK_EXT_VERTEX_ATTRIBUTE_DIVISOR_SPEC_VERSION 1
+#define VK_EXT_VERTEX_ATTRIBUTE_DIVISOR_EXTENSION_NAME "VK_EXT_vertex_attribute_divisor"
+
+typedef struct VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t maxVertexAttribDivisor;
+} VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT;
+
+typedef struct VkVertexInputBindingDivisorDescriptionEXT {
+ uint32_t binding;
+ uint32_t divisor;
+} VkVertexInputBindingDivisorDescriptionEXT;
+
+typedef struct VkPipelineVertexInputDivisorStateCreateInfoEXT {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t vertexBindingDivisorCount;
+ const VkVertexInputBindingDivisorDescriptionEXT* pVertexBindingDivisors;
+} VkPipelineVertexInputDivisorStateCreateInfoEXT;
+
+
+
+#define VK_NV_shader_subgroup_partitioned 1
+#define VK_NV_SHADER_SUBGROUP_PARTITIONED_SPEC_VERSION 1
+#define VK_NV_SHADER_SUBGROUP_PARTITIONED_EXTENSION_NAME "VK_NV_shader_subgroup_partitioned"
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_IOS_H_
+#define VULKAN_IOS_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_MVK_ios_surface 1
+#define VK_MVK_IOS_SURFACE_SPEC_VERSION 2
+#define VK_MVK_IOS_SURFACE_EXTENSION_NAME "VK_MVK_ios_surface"
+
+typedef VkFlags VkIOSSurfaceCreateFlagsMVK;
+
+typedef struct VkIOSSurfaceCreateInfoMVK {
+ VkStructureType sType;
+ const void* pNext;
+ VkIOSSurfaceCreateFlagsMVK flags;
+ const void* pView;
+} VkIOSSurfaceCreateInfoMVK;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateIOSSurfaceMVK)(VkInstance instance, const VkIOSSurfaceCreateInfoMVK* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateIOSSurfaceMVK(
+ VkInstance instance,
+ const VkIOSSurfaceCreateInfoMVK* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_MACOS_H_
+#define VULKAN_MACOS_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_MVK_macos_surface 1
+#define VK_MVK_MACOS_SURFACE_SPEC_VERSION 2
+#define VK_MVK_MACOS_SURFACE_EXTENSION_NAME "VK_MVK_macos_surface"
+
+typedef VkFlags VkMacOSSurfaceCreateFlagsMVK;
+
+typedef struct VkMacOSSurfaceCreateInfoMVK {
+ VkStructureType sType;
+ const void* pNext;
+ VkMacOSSurfaceCreateFlagsMVK flags;
+ const void* pView;
+} VkMacOSSurfaceCreateInfoMVK;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateMacOSSurfaceMVK)(VkInstance instance, const VkMacOSSurfaceCreateInfoMVK* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateMacOSSurfaceMVK(
+ VkInstance instance,
+ const VkMacOSSurfaceCreateInfoMVK* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_MIR_H_
+#define VULKAN_MIR_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_KHR_mir_surface 1
+#define VK_KHR_MIR_SURFACE_SPEC_VERSION 4
+#define VK_KHR_MIR_SURFACE_EXTENSION_NAME "VK_KHR_mir_surface"
+
+typedef VkFlags VkMirSurfaceCreateFlagsKHR;
+
+typedef struct VkMirSurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkMirSurfaceCreateFlagsKHR flags;
+ MirConnection* connection;
+ MirSurface* mirSurface;
+} VkMirSurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateMirSurfaceKHR)(VkInstance instance, const VkMirSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceMirPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, MirConnection* connection);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateMirSurfaceKHR(
+ VkInstance instance,
+ const VkMirSurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+
+VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceMirPresentationSupportKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t queueFamilyIndex,
+ MirConnection* connection);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_VI_H_
+#define VULKAN_VI_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_NN_vi_surface 1
+#define VK_NN_VI_SURFACE_SPEC_VERSION 1
+#define VK_NN_VI_SURFACE_EXTENSION_NAME "VK_NN_vi_surface"
+
+typedef VkFlags VkViSurfaceCreateFlagsNN;
+
+typedef struct VkViSurfaceCreateInfoNN {
+ VkStructureType sType;
+ const void* pNext;
+ VkViSurfaceCreateFlagsNN flags;
+ void* window;
+} VkViSurfaceCreateInfoNN;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateViSurfaceNN)(VkInstance instance, const VkViSurfaceCreateInfoNN* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateViSurfaceNN(
+ VkInstance instance,
+ const VkViSurfaceCreateInfoNN* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_WAYLAND_H_
+#define VULKAN_WAYLAND_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_KHR_wayland_surface 1
+#define VK_KHR_WAYLAND_SURFACE_SPEC_VERSION 6
+#define VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME "VK_KHR_wayland_surface"
+
+typedef VkFlags VkWaylandSurfaceCreateFlagsKHR;
+
+typedef struct VkWaylandSurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkWaylandSurfaceCreateFlagsKHR flags;
+ struct wl_display* display;
+ struct wl_surface* surface;
+} VkWaylandSurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateWaylandSurfaceKHR)(VkInstance instance, const VkWaylandSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, struct wl_display* display);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateWaylandSurfaceKHR(
+ VkInstance instance,
+ const VkWaylandSurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+
+VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceWaylandPresentationSupportKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t queueFamilyIndex,
+ struct wl_display* display);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_WIN32_H_
+#define VULKAN_WIN32_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_KHR_win32_surface 1
+#define VK_KHR_WIN32_SURFACE_SPEC_VERSION 6
+#define VK_KHR_WIN32_SURFACE_EXTENSION_NAME "VK_KHR_win32_surface"
+
+typedef VkFlags VkWin32SurfaceCreateFlagsKHR;
+
+typedef struct VkWin32SurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkWin32SurfaceCreateFlagsKHR flags;
+ HINSTANCE hinstance;
+ HWND hwnd;
+} VkWin32SurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateWin32SurfaceKHR)(VkInstance instance, const VkWin32SurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateWin32SurfaceKHR(
+ VkInstance instance,
+ const VkWin32SurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+
+VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceWin32PresentationSupportKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t queueFamilyIndex);
+#endif
+
+#define VK_KHR_external_memory_win32 1
+#define VK_KHR_EXTERNAL_MEMORY_WIN32_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_MEMORY_WIN32_EXTENSION_NAME "VK_KHR_external_memory_win32"
+
+typedef struct VkImportMemoryWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+ HANDLE handle;
+ LPCWSTR name;
+} VkImportMemoryWin32HandleInfoKHR;
+
+typedef struct VkExportMemoryWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ const SECURITY_ATTRIBUTES* pAttributes;
+ DWORD dwAccess;
+ LPCWSTR name;
+} VkExportMemoryWin32HandleInfoKHR;
+
+typedef struct VkMemoryWin32HandlePropertiesKHR {
+ VkStructureType sType;
+ void* pNext;
+ uint32_t memoryTypeBits;
+} VkMemoryWin32HandlePropertiesKHR;
+
+typedef struct VkMemoryGetWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkDeviceMemory memory;
+ VkExternalMemoryHandleTypeFlagBits handleType;
+} VkMemoryGetWin32HandleInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryWin32HandleKHR)(VkDevice device, const VkMemoryGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle);
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryWin32HandlePropertiesKHR)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, HANDLE handle, VkMemoryWin32HandlePropertiesKHR* pMemoryWin32HandleProperties);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryWin32HandleKHR(
+ VkDevice device,
+ const VkMemoryGetWin32HandleInfoKHR* pGetWin32HandleInfo,
+ HANDLE* pHandle);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryWin32HandlePropertiesKHR(
+ VkDevice device,
+ VkExternalMemoryHandleTypeFlagBits handleType,
+ HANDLE handle,
+ VkMemoryWin32HandlePropertiesKHR* pMemoryWin32HandleProperties);
+#endif
+
+#define VK_KHR_win32_keyed_mutex 1
+#define VK_KHR_WIN32_KEYED_MUTEX_SPEC_VERSION 1
+#define VK_KHR_WIN32_KEYED_MUTEX_EXTENSION_NAME "VK_KHR_win32_keyed_mutex"
+
+typedef struct VkWin32KeyedMutexAcquireReleaseInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t acquireCount;
+ const VkDeviceMemory* pAcquireSyncs;
+ const uint64_t* pAcquireKeys;
+ const uint32_t* pAcquireTimeouts;
+ uint32_t releaseCount;
+ const VkDeviceMemory* pReleaseSyncs;
+ const uint64_t* pReleaseKeys;
+} VkWin32KeyedMutexAcquireReleaseInfoKHR;
+
+
+
+#define VK_KHR_external_semaphore_win32 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_WIN32_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_SEMAPHORE_WIN32_EXTENSION_NAME "VK_KHR_external_semaphore_win32"
+
+typedef struct VkImportSemaphoreWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSemaphore semaphore;
+ VkSemaphoreImportFlags flags;
+ VkExternalSemaphoreHandleTypeFlagBits handleType;
+ HANDLE handle;
+ LPCWSTR name;
+} VkImportSemaphoreWin32HandleInfoKHR;
+
+typedef struct VkExportSemaphoreWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ const SECURITY_ATTRIBUTES* pAttributes;
+ DWORD dwAccess;
+ LPCWSTR name;
+} VkExportSemaphoreWin32HandleInfoKHR;
+
+typedef struct VkD3D12FenceSubmitInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t waitSemaphoreValuesCount;
+ const uint64_t* pWaitSemaphoreValues;
+ uint32_t signalSemaphoreValuesCount;
+ const uint64_t* pSignalSemaphoreValues;
+} VkD3D12FenceSubmitInfoKHR;
+
+typedef struct VkSemaphoreGetWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkSemaphore semaphore;
+ VkExternalSemaphoreHandleTypeFlagBits handleType;
+} VkSemaphoreGetWin32HandleInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkImportSemaphoreWin32HandleKHR)(VkDevice device, const VkImportSemaphoreWin32HandleInfoKHR* pImportSemaphoreWin32HandleInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkGetSemaphoreWin32HandleKHR)(VkDevice device, const VkSemaphoreGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkImportSemaphoreWin32HandleKHR(
+ VkDevice device,
+ const VkImportSemaphoreWin32HandleInfoKHR* pImportSemaphoreWin32HandleInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetSemaphoreWin32HandleKHR(
+ VkDevice device,
+ const VkSemaphoreGetWin32HandleInfoKHR* pGetWin32HandleInfo,
+ HANDLE* pHandle);
+#endif
+
+#define VK_KHR_external_fence_win32 1
+#define VK_KHR_EXTERNAL_FENCE_WIN32_SPEC_VERSION 1
+#define VK_KHR_EXTERNAL_FENCE_WIN32_EXTENSION_NAME "VK_KHR_external_fence_win32"
+
+typedef struct VkImportFenceWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkFence fence;
+ VkFenceImportFlags flags;
+ VkExternalFenceHandleTypeFlagBits handleType;
+ HANDLE handle;
+ LPCWSTR name;
+} VkImportFenceWin32HandleInfoKHR;
+
+typedef struct VkExportFenceWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ const SECURITY_ATTRIBUTES* pAttributes;
+ DWORD dwAccess;
+ LPCWSTR name;
+} VkExportFenceWin32HandleInfoKHR;
+
+typedef struct VkFenceGetWin32HandleInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkFence fence;
+ VkExternalFenceHandleTypeFlagBits handleType;
+} VkFenceGetWin32HandleInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkImportFenceWin32HandleKHR)(VkDevice device, const VkImportFenceWin32HandleInfoKHR* pImportFenceWin32HandleInfo);
+typedef VkResult (VKAPI_PTR *PFN_vkGetFenceWin32HandleKHR)(VkDevice device, const VkFenceGetWin32HandleInfoKHR* pGetWin32HandleInfo, HANDLE* pHandle);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkImportFenceWin32HandleKHR(
+ VkDevice device,
+ const VkImportFenceWin32HandleInfoKHR* pImportFenceWin32HandleInfo);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetFenceWin32HandleKHR(
+ VkDevice device,
+ const VkFenceGetWin32HandleInfoKHR* pGetWin32HandleInfo,
+ HANDLE* pHandle);
+#endif
+
+#define VK_NV_external_memory_win32 1
+#define VK_NV_EXTERNAL_MEMORY_WIN32_SPEC_VERSION 1
+#define VK_NV_EXTERNAL_MEMORY_WIN32_EXTENSION_NAME "VK_NV_external_memory_win32"
+
+typedef struct VkImportMemoryWin32HandleInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ VkExternalMemoryHandleTypeFlagsNV handleType;
+ HANDLE handle;
+} VkImportMemoryWin32HandleInfoNV;
+
+typedef struct VkExportMemoryWin32HandleInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ const SECURITY_ATTRIBUTES* pAttributes;
+ DWORD dwAccess;
+} VkExportMemoryWin32HandleInfoNV;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryWin32HandleNV)(VkDevice device, VkDeviceMemory memory, VkExternalMemoryHandleTypeFlagsNV handleType, HANDLE* pHandle);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryWin32HandleNV(
+ VkDevice device,
+ VkDeviceMemory memory,
+ VkExternalMemoryHandleTypeFlagsNV handleType,
+ HANDLE* pHandle);
+#endif
+
+#define VK_NV_win32_keyed_mutex 1
+#define VK_NV_WIN32_KEYED_MUTEX_SPEC_VERSION 1
+#define VK_NV_WIN32_KEYED_MUTEX_EXTENSION_NAME "VK_NV_win32_keyed_mutex"
+
+typedef struct VkWin32KeyedMutexAcquireReleaseInfoNV {
+ VkStructureType sType;
+ const void* pNext;
+ uint32_t acquireCount;
+ const VkDeviceMemory* pAcquireSyncs;
+ const uint64_t* pAcquireKeys;
+ const uint32_t* pAcquireTimeoutMilliseconds;
+ uint32_t releaseCount;
+ const VkDeviceMemory* pReleaseSyncs;
+ const uint64_t* pReleaseKeys;
+} VkWin32KeyedMutexAcquireReleaseInfoNV;
+
+
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_XCB_H_
+#define VULKAN_XCB_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_KHR_xcb_surface 1
+#define VK_KHR_XCB_SURFACE_SPEC_VERSION 6
+#define VK_KHR_XCB_SURFACE_EXTENSION_NAME "VK_KHR_xcb_surface"
+
+typedef VkFlags VkXcbSurfaceCreateFlagsKHR;
+
+typedef struct VkXcbSurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkXcbSurfaceCreateFlagsKHR flags;
+ xcb_connection_t* connection;
+ xcb_window_t window;
+} VkXcbSurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateXcbSurfaceKHR)(VkInstance instance, const VkXcbSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, xcb_connection_t* connection, xcb_visualid_t visual_id);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateXcbSurfaceKHR(
+ VkInstance instance,
+ const VkXcbSurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+
+VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceXcbPresentationSupportKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t queueFamilyIndex,
+ xcb_connection_t* connection,
+ xcb_visualid_t visual_id);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_XLIB_H_
+#define VULKAN_XLIB_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_KHR_xlib_surface 1
+#define VK_KHR_XLIB_SURFACE_SPEC_VERSION 6
+#define VK_KHR_XLIB_SURFACE_EXTENSION_NAME "VK_KHR_xlib_surface"
+
+typedef VkFlags VkXlibSurfaceCreateFlagsKHR;
+
+typedef struct VkXlibSurfaceCreateInfoKHR {
+ VkStructureType sType;
+ const void* pNext;
+ VkXlibSurfaceCreateFlagsKHR flags;
+ Display* dpy;
+ Window window;
+} VkXlibSurfaceCreateInfoKHR;
+
+
+typedef VkResult (VKAPI_PTR *PFN_vkCreateXlibSurfaceKHR)(VkInstance instance, const VkXlibSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
+typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, Display* dpy, VisualID visualID);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkCreateXlibSurfaceKHR(
+ VkInstance instance,
+ const VkXlibSurfaceCreateInfoKHR* pCreateInfo,
+ const VkAllocationCallbacks* pAllocator,
+ VkSurfaceKHR* pSurface);
+
+VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceXlibPresentationSupportKHR(
+ VkPhysicalDevice physicalDevice,
+ uint32_t queueFamilyIndex,
+ Display* dpy,
+ VisualID visualID);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#ifndef VULKAN_XLIB_XRANDR_H_
+#define VULKAN_XLIB_XRANDR_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/*
+** Copyright (c) 2015-2018 The Khronos Group 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.
+*/
+
+/*
+** This header is generated from the Khronos Vulkan XML API Registry.
+**
+*/
+
+
+#define VK_EXT_acquire_xlib_display 1
+#define VK_EXT_ACQUIRE_XLIB_DISPLAY_SPEC_VERSION 1
+#define VK_EXT_ACQUIRE_XLIB_DISPLAY_EXTENSION_NAME "VK_EXT_acquire_xlib_display"
+
+typedef VkResult (VKAPI_PTR *PFN_vkAcquireXlibDisplayEXT)(VkPhysicalDevice physicalDevice, Display* dpy, VkDisplayKHR display);
+typedef VkResult (VKAPI_PTR *PFN_vkGetRandROutputDisplayEXT)(VkPhysicalDevice physicalDevice, Display* dpy, RROutput rrOutput, VkDisplayKHR* pDisplay);
+
+#ifndef VK_NO_PROTOTYPES
+VKAPI_ATTR VkResult VKAPI_CALL vkAcquireXlibDisplayEXT(
+ VkPhysicalDevice physicalDevice,
+ Display* dpy,
+ VkDisplayKHR display);
+
+VKAPI_ATTR VkResult VKAPI_CALL vkGetRandROutputDisplayEXT(
+ VkPhysicalDevice physicalDevice,
+ Display* dpy,
+ RROutput rrOutput,
+ VkDisplayKHR* pDisplay);
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+#!/usr/bin/python3 -i
+#
+# Copyright (c) 2013-2018 The Khronos Group 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.
+
+import os,re,sys,pdb
+from generator import *
+
+# CGeneratorOptions - subclass of GeneratorOptions.
+#
+# Adds options used by COutputGenerator objects during C language header
+# generation.
+#
+# Additional members
+# prefixText - list of strings to prefix generated header with
+# (usually a copyright statement + calling convention macros).
+# protectFile - True if multiple inclusion protection should be
+# generated (based on the filename) around the entire header.
+# protectFeature - True if #ifndef..#endif protection should be
+# generated around a feature interface in the header file.
+# genFuncPointers - True if function pointer typedefs should be
+# generated
+# protectProto - If conditional protection should be generated
+# around prototype declarations, set to either '#ifdef'
+# to require opt-in (#ifdef protectProtoStr) or '#ifndef'
+# to require opt-out (#ifndef protectProtoStr). Otherwise
+# set to None.
+# protectProtoStr - #ifdef/#ifndef symbol to use around prototype
+# declarations, if protectProto is set
+# apicall - string to use for the function declaration prefix,
+# such as APICALL on Windows.
+# apientry - string to use for the calling convention macro,
+# in typedefs, such as APIENTRY.
+# apientryp - string to use for the calling convention macro
+# in function pointer typedefs, such as APIENTRYP.
+# directory - directory into which to generate include files
+# indentFuncProto - True if prototype declarations should put each
+# parameter on a separate line
+# indentFuncPointer - True if typedefed function pointers should put each
+# parameter on a separate line
+# alignFuncParam - if nonzero and parameters are being put on a
+# separate line, align parameter names at the specified column
+class CGeneratorOptions(GeneratorOptions):
+ """Represents options during C interface generation for headers"""
+ def __init__(self,
+ filename = None,
+ directory = '.',
+ apiname = None,
+ profile = None,
+ versions = '.*',
+ emitversions = '.*',
+ defaultExtensions = None,
+ addExtensions = None,
+ removeExtensions = None,
+ emitExtensions = None,
+ sortProcedure = regSortFeatures,
+ prefixText = "",
+ genFuncPointers = True,
+ protectFile = True,
+ protectFeature = True,
+ protectProto = None,
+ protectProtoStr = None,
+ apicall = '',
+ apientry = '',
+ apientryp = '',
+ indentFuncProto = True,
+ indentFuncPointer = False,
+ alignFuncParam = 0):
+ GeneratorOptions.__init__(self, filename, directory, apiname, profile,
+ versions, emitversions, defaultExtensions,
+ addExtensions, removeExtensions,
+ emitExtensions, sortProcedure)
+ self.prefixText = prefixText
+ self.genFuncPointers = genFuncPointers
+ self.protectFile = protectFile
+ self.protectFeature = protectFeature
+ self.protectProto = protectProto
+ self.protectProtoStr = protectProtoStr
+ self.apicall = apicall
+ self.apientry = apientry
+ self.apientryp = apientryp
+ self.indentFuncProto = indentFuncProto
+ self.indentFuncPointer = indentFuncPointer
+ self.alignFuncParam = alignFuncParam
+
+# COutputGenerator - subclass of OutputGenerator.
+# Generates C-language API interfaces.
+#
+# ---- methods ----
+# COutputGenerator(errFile, warnFile, diagFile) - args as for
+# OutputGenerator. Defines additional internal state.
+# ---- methods overriding base class ----
+# beginFile(genOpts)
+# endFile()
+# beginFeature(interface, emit)
+# endFeature()
+# genType(typeinfo,name)
+# genStruct(typeinfo,name)
+# genGroup(groupinfo,name)
+# genEnum(enuminfo, name)
+# genCmd(cmdinfo)
+class COutputGenerator(OutputGenerator):
+ """Generate specified API interfaces in a specific style, such as a C header"""
+ # This is an ordered list of sections in the header file.
+ TYPE_SECTIONS = ['include', 'define', 'basetype', 'handle', 'enum',
+ 'group', 'bitmask', 'funcpointer', 'struct']
+ ALL_SECTIONS = TYPE_SECTIONS + ['commandPointer', 'command']
+ def __init__(self,
+ errFile = sys.stderr,
+ warnFile = sys.stderr,
+ diagFile = sys.stdout):
+ OutputGenerator.__init__(self, errFile, warnFile, diagFile)
+ # Internal state - accumulators for different inner block text
+ self.sections = dict([(section, []) for section in self.ALL_SECTIONS])
+ #
+ def beginFile(self, genOpts):
+ OutputGenerator.beginFile(self, genOpts)
+ # C-specific
+ #
+ # Multiple inclusion protection & C++ wrappers.
+ if (genOpts.protectFile and self.genOpts.filename):
+ headerSym = re.sub('\.h', '_h_',
+ os.path.basename(self.genOpts.filename)).upper()
+ write('#ifndef', headerSym, file=self.outFile)
+ write('#define', headerSym, '1', file=self.outFile)
+ self.newline()
+ write('#ifdef __cplusplus', file=self.outFile)
+ write('extern "C" {', file=self.outFile)
+ write('#endif', file=self.outFile)
+ self.newline()
+ #
+ # User-supplied prefix text, if any (list of strings)
+ if (genOpts.prefixText):
+ for s in genOpts.prefixText:
+ write(s, file=self.outFile)
+ #
+ # Some boilerplate describing what was generated - this
+ # will probably be removed later since the extensions
+ # pattern may be very long.
+ # write('/* Generated C header for:', file=self.outFile)
+ # write(' * API:', genOpts.apiname, file=self.outFile)
+ # if (genOpts.profile):
+ # write(' * Profile:', genOpts.profile, file=self.outFile)
+ # write(' * Versions considered:', genOpts.versions, file=self.outFile)
+ # write(' * Versions emitted:', genOpts.emitversions, file=self.outFile)
+ # write(' * Default extensions included:', genOpts.defaultExtensions, file=self.outFile)
+ # write(' * Additional extensions included:', genOpts.addExtensions, file=self.outFile)
+ # write(' * Extensions removed:', genOpts.removeExtensions, file=self.outFile)
+ # write(' * Extensions emitted:', genOpts.emitExtensions, file=self.outFile)
+ # write(' */', file=self.outFile)
+ def endFile(self):
+ # C-specific
+ # Finish C++ wrapper and multiple inclusion protection
+ self.newline()
+ write('#ifdef __cplusplus', file=self.outFile)
+ write('}', file=self.outFile)
+ write('#endif', file=self.outFile)
+ if (self.genOpts.protectFile and self.genOpts.filename):
+ self.newline()
+ write('#endif', file=self.outFile)
+ # Finish processing in superclass
+ OutputGenerator.endFile(self)
+ def beginFeature(self, interface, emit):
+ # Start processing in superclass
+ OutputGenerator.beginFeature(self, interface, emit)
+ # C-specific
+ # Accumulate includes, defines, types, enums, function pointer typedefs,
+ # end function prototypes separately for this feature. They're only
+ # printed in endFeature().
+ self.sections = dict([(section, []) for section in self.ALL_SECTIONS])
+ def endFeature(self):
+ # C-specific
+ # Actually write the interface to the output file.
+ if (self.emit):
+ self.newline()
+ if (self.genOpts.protectFeature):
+ write('#ifndef', self.featureName, file=self.outFile)
+ # If type declarations are needed by other features based on
+ # this one, it may be necessary to suppress the ExtraProtect,
+ # or move it below the 'for section...' loop.
+ if (self.featureExtraProtect != None):
+ write('#ifdef', self.featureExtraProtect, file=self.outFile)
+ write('#define', self.featureName, '1', file=self.outFile)
+ for section in self.TYPE_SECTIONS:
+ contents = self.sections[section]
+ if contents:
+ write('\n'.join(contents), file=self.outFile)
+ self.newline()
+ if (self.genOpts.genFuncPointers and self.sections['commandPointer']):
+ write('\n'.join(self.sections['commandPointer']), file=self.outFile)
+ self.newline()
+ if (self.sections['command']):
+ if (self.genOpts.protectProto):
+ write(self.genOpts.protectProto,
+ self.genOpts.protectProtoStr, file=self.outFile)
+ write('\n'.join(self.sections['command']), end='', file=self.outFile)
+ if (self.genOpts.protectProto):
+ write('#endif', file=self.outFile)
+ else:
+ self.newline()
+ if (self.featureExtraProtect != None):
+ write('#endif /*', self.featureExtraProtect, '*/', file=self.outFile)
+ if (self.genOpts.protectFeature):
+ write('#endif /*', self.featureName, '*/', file=self.outFile)
+ # Finish processing in superclass
+ OutputGenerator.endFeature(self)
+ #
+ # Append a definition to the specified section
+ def appendSection(self, section, text):
+ # self.sections[section].append('SECTION: ' + section + '\n')
+ self.sections[section].append(text)
+ # self.logMsg('diag', 'appendSection(section =', section, 'text =', text)
+ #
+ # Type generation
+ def genType(self, typeinfo, name, alias):
+ OutputGenerator.genType(self, typeinfo, name, alias)
+ typeElem = typeinfo.elem
+
+ # Determine the category of the type, and the type section to add
+ # its definition to.
+ # 'funcpointer' is added to the 'struct' section as a workaround for
+ # internal issue #877, since structures and function pointer types
+ # can have cross-dependencies.
+ category = typeElem.get('category')
+ if category == 'funcpointer':
+ section = 'struct'
+ else:
+ section = category
+
+ if category == 'struct' or category == 'union':
+ # If the type is a struct type, generate it using the
+ # special-purpose generator.
+ self.genStruct(typeinfo, name, alias)
+ else:
+ if alias:
+ # If the type is an alias, just emit a typedef declaration
+ body = 'typedef ' + alias + ' ' + name + ';\n'
+ else:
+ # Replace <apientry /> tags with an APIENTRY-style string
+ # (from self.genOpts). Copy other text through unchanged.
+ # If the resulting text is an empty string, don't emit it.
+ body = noneStr(typeElem.text)
+ for elem in typeElem:
+ if (elem.tag == 'apientry'):
+ body += self.genOpts.apientry + noneStr(elem.tail)
+ else:
+ body += noneStr(elem.text) + noneStr(elem.tail)
+
+ if body:
+ # Add extra newline after multi-line entries.
+ if '\n' in body[0:-1]:
+ body += '\n'
+ self.appendSection(section, body)
+ #
+ # Struct (e.g. C "struct" type) generation.
+ # This is a special case of the <type> tag where the contents are
+ # interpreted as a set of <member> tags instead of freeform C
+ # C type declarations. The <member> tags are just like <param>
+ # tags - they are a declaration of a struct or union member.
+ # Only simple member declarations are supported (no nested
+ # structs etc.)
+ # If alias != None, then this struct aliases another; just
+ # generate a typedef of that alias.
+ def genStruct(self, typeinfo, typeName, alias):
+ OutputGenerator.genStruct(self, typeinfo, typeName, alias)
+
+ typeElem = typeinfo.elem
+
+ if alias:
+ body = 'typedef ' + alias + ' ' + typeName + ';\n'
+ else:
+ body = 'typedef ' + typeElem.get('category') + ' ' + typeName + ' {\n'
+
+ targetLen = 0;
+ for member in typeElem.findall('.//member'):
+ targetLen = max(targetLen, self.getCParamTypeLength(member))
+ for member in typeElem.findall('.//member'):
+ body += self.makeCParamDecl(member, targetLen + 4)
+ body += ';\n'
+ body += '} ' + typeName + ';\n'
+
+ self.appendSection('struct', body)
+ #
+ # Group (e.g. C "enum" type) generation.
+ # These are concatenated together with other types.
+ # If alias != None, it is the name of another group type
+ # which aliases this type; just generate that alias.
+ def genGroup(self, groupinfo, groupName, alias = None):
+ OutputGenerator.genGroup(self, groupinfo, groupName, alias)
+ groupElem = groupinfo.elem
+
+ if alias:
+ # If the group name is aliased, just emit a typedef declaration
+ # for the alias.
+ body = 'typedef ' + alias + ' ' + groupName + ';\n'
+ else:
+ self.logMsg('diag', 'CGenerator.genGroup group =', groupName, 'alias =', alias)
+
+ # Otherwise, emit an actual enumerated type declaration
+ expandName = re.sub(r'([0-9a-z_])([A-Z0-9])',r'\1_\2',groupName).upper()
+
+ expandPrefix = expandName
+ expandSuffix = ''
+ expandSuffixMatch = re.search(r'[A-Z][A-Z]+$',groupName)
+ if expandSuffixMatch:
+ expandSuffix = '_' + expandSuffixMatch.group()
+ # Strip off the suffix from the prefix
+ expandPrefix = expandName.rsplit(expandSuffix, 1)[0]
+
+ # Prefix
+ body = "\ntypedef enum " + groupName + " {\n"
+
+ # @@ Should use the type="bitmask" attribute instead
+ isEnum = ('FLAG_BITS' not in expandPrefix)
+
+ # Get a list of nested 'enum' tags.
+ enums = groupElem.findall('enum')
+
+ # Check for and report duplicates, and return a list with them
+ # removed.
+ enums = self.checkDuplicateEnums(enums)
+
+ # Loop over the nested 'enum' tags. Keep track of the minimum and
+ # maximum numeric values, if they can be determined; but only for
+ # core API enumerants, not extension enumerants. This is inferred
+ # by looking for 'extends' attributes.
+ minName = None
+
+ # Accumulate non-numeric enumerant values separately and append
+ # them following the numeric values, to allow for aliases.
+ # NOTE: this doesn't do a topological sort yet, so aliases of
+ # aliases can still get in the wrong order.
+ aliasText = ""
+
+ for elem in enums:
+ # Convert the value to an integer and use that to track min/max.
+ (numVal,strVal) = self.enumToValue(elem, True)
+ name = elem.get('name')
+
+ # Extension enumerants are only included if they are required
+ if self.isEnumRequired(elem):
+ decl = " " + name + " = " + strVal + ",\n"
+ if numVal != None:
+ body += decl
+ else:
+ aliasText += decl
+
+ # Don't track min/max for non-numbers (numVal == None)
+ if isEnum and numVal != None and elem.get('extends') is None:
+ if minName == None:
+ minName = maxName = name
+ minValue = maxValue = numVal
+ elif numVal < minValue:
+ minName = name
+ minValue = numVal
+ elif numVal > maxValue:
+ maxName = name
+ maxValue = numVal
+
+ # Now append the non-numeric enumerant values
+ body += aliasText
+
+ # Generate min/max value tokens and a range-padding enum. Need some
+ # additional padding to generate correct names...
+ if isEnum:
+ body += " " + expandPrefix + "_BEGIN_RANGE" + expandSuffix + " = " + minName + ",\n"
+ body += " " + expandPrefix + "_END_RANGE" + expandSuffix + " = " + maxName + ",\n"
+ body += " " + expandPrefix + "_RANGE_SIZE" + expandSuffix + " = (" + maxName + " - " + minName + " + 1),\n"
+
+ body += " " + expandPrefix + "_MAX_ENUM" + expandSuffix + " = 0x7FFFFFFF\n"
+
+ # Postfix
+ body += "} " + groupName + ";"
+
+ # After either enumerated type or alias paths, add the declaration
+ # to the appropriate section for the group being defined.
+ if groupElem.get('type') == 'bitmask':
+ section = 'bitmask'
+ else:
+ section = 'group'
+ self.appendSection(section, body)
+
+ # Enumerant generation
+ # <enum> tags may specify their values in several ways, but are usually
+ # just integers.
+ def genEnum(self, enuminfo, name, alias):
+ OutputGenerator.genEnum(self, enuminfo, name, alias)
+ (numVal,strVal) = self.enumToValue(enuminfo.elem, False)
+ body = '#define ' + name.ljust(33) + ' ' + strVal
+ self.appendSection('enum', body)
+
+ #
+ # Command generation
+ def genCmd(self, cmdinfo, name, alias):
+ OutputGenerator.genCmd(self, cmdinfo, name, alias)
+
+ # if alias:
+ # prefix = '// ' + name + ' is an alias of command ' + alias + '\n'
+ # else:
+ # prefix = ''
+
+ prefix = ''
+ decls = self.makeCDecls(cmdinfo.elem)
+ self.appendSection('command', prefix + decls[0] + '\n')
+ if (self.genOpts.genFuncPointers):
+ self.appendSection('commandPointer', decls[1])
--- /dev/null
+#!/usr/bin/python3 -i
+#
+# Copyright (c) 2013-2018 The Khronos Group 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.
+
+from __future__ import unicode_literals
+import io,os,re,sys,pdb
+
+def write( *args, **kwargs ):
+ file = kwargs.pop('file',sys.stdout)
+ end = kwargs.pop('end','\n')
+ file.write(' '.join([str(arg) for arg in args]))
+ file.write(end)
+
+# noneStr - returns string argument, or "" if argument is None.
+# Used in converting etree Elements into text.
+# str - string to convert
+def noneStr(str):
+ if (str):
+ return str
+ else:
+ return ""
+
+# enquote - returns string argument with surrounding quotes,
+# for serialization into Python code.
+def enquote(str):
+ if (str):
+ return "'" + str + "'"
+ else:
+ return None
+
+# apiName - returns True if name is a Vulkan name (vk/Vk/VK prefix, or a
+# function pointer type), False otherwise.
+def apiName(str):
+ return str[0:2].lower() == 'vk' or str[0:3] == 'PFN'
+
+# Primary sort key for regSortFeatures.
+# Sorts by category of the feature name string:
+# Core API features (those defined with a <feature> tag)
+# ARB/KHR/OES (Khronos extensions)
+# other (EXT/vendor extensions)
+# This will need changing for Vulkan!
+def regSortCategoryKey(feature):
+ if (feature.elem.tag == 'feature'):
+ return 0
+ elif (feature.category == 'ARB' or
+ feature.category == 'KHR' or
+ feature.category == 'OES'):
+ return 1
+ else:
+ return 2
+
+# Secondary sort key for regSortFeatures.
+# Sorts by extension name.
+def regSortNameKey(feature):
+ return feature.name
+
+# Second sort key for regSortFeatures.
+# Sorts by feature version. <extension> elements all have version number "0"
+def regSortFeatureVersionKey(feature):
+ return float(feature.versionNumber)
+
+# Tertiary sort key for regSortFeatures.
+# Sorts by extension number. <feature> elements all have extension number 0.
+def regSortExtensionNumberKey(feature):
+ return int(feature.number)
+
+# regSortFeatures - default sort procedure for features.
+# Sorts by primary key of feature category ('feature' or 'extension')
+# then by version number (for features)
+# then by extension number (for extensions)
+def regSortFeatures(featureList):
+ featureList.sort(key = regSortExtensionNumberKey)
+ featureList.sort(key = regSortFeatureVersionKey)
+ featureList.sort(key = regSortCategoryKey)
+
+# GeneratorOptions - base class for options used during header production
+# These options are target language independent, and used by
+# Registry.apiGen() and by base OutputGenerator objects.
+#
+# Members
+# filename - basename of file to generate, or None to write to stdout.
+# directory - directory in which to generate filename
+# apiname - string matching <api> 'apiname' attribute, e.g. 'gl'.
+# profile - string specifying API profile , e.g. 'core', or None.
+# versions - regex matching API versions to process interfaces for.
+# Normally '.*' or '[0-9]\.[0-9]' to match all defined versions.
+# emitversions - regex matching API versions to actually emit
+# interfaces for (though all requested versions are considered
+# when deciding which interfaces to generate). For GL 4.3 glext.h,
+# this might be '1\.[2-5]|[2-4]\.[0-9]'.
+# defaultExtensions - If not None, a string which must in its
+# entirety match the pattern in the "supported" attribute of
+# the <extension>. Defaults to None. Usually the same as apiname.
+# addExtensions - regex matching names of additional extensions
+# to include. Defaults to None.
+# removeExtensions - regex matching names of extensions to
+# remove (after defaultExtensions and addExtensions). Defaults
+# to None.
+# emitExtensions - regex matching names of extensions to actually emit
+# interfaces for (though all requested versions are considered when
+# deciding which interfaces to generate).
+# sortProcedure - takes a list of FeatureInfo objects and sorts
+# them in place to a preferred order in the generated output.
+# Default is core API versions, ARB/KHR/OES extensions, all
+# other extensions, alphabetically within each group.
+# The regex patterns can be None or empty, in which case they match
+# nothing.
+class GeneratorOptions:
+ """Represents options during header production from an API registry"""
+ def __init__(self,
+ filename = None,
+ directory = '.',
+ apiname = None,
+ profile = None,
+ versions = '.*',
+ emitversions = '.*',
+ defaultExtensions = None,
+ addExtensions = None,
+ removeExtensions = None,
+ emitExtensions = None,
+ sortProcedure = regSortFeatures):
+ self.filename = filename
+ self.directory = directory
+ self.apiname = apiname
+ self.profile = profile
+ self.versions = self.emptyRegex(versions)
+ self.emitversions = self.emptyRegex(emitversions)
+ self.defaultExtensions = defaultExtensions
+ self.addExtensions = self.emptyRegex(addExtensions)
+ self.removeExtensions = self.emptyRegex(removeExtensions)
+ self.emitExtensions = self.emptyRegex(emitExtensions)
+ self.sortProcedure = sortProcedure
+ #
+ # Substitute a regular expression which matches no version
+ # or extension names for None or the empty string.
+ def emptyRegex(self,pat):
+ if (pat == None or pat == ''):
+ return '_nomatch_^'
+ else:
+ return pat
+
+# OutputGenerator - base class for generating API interfaces.
+# Manages basic logic, logging, and output file control
+# Derived classes actually generate formatted output.
+#
+# ---- methods ----
+# OutputGenerator(errFile, warnFile, diagFile)
+# errFile, warnFile, diagFile - file handles to write errors,
+# warnings, diagnostics to. May be None to not write.
+# logMsg(level, *args) - log messages of different categories
+# level - 'error', 'warn', or 'diag'. 'error' will also
+# raise a UserWarning exception
+# *args - print()-style arguments
+# setExtMap(map) - specify a dictionary map from extension names to
+# numbers, used in creating values for extension enumerants.
+# makeDir(directory) - create a directory, if not already done.
+# Generally called from derived generators creating hierarchies.
+# beginFile(genOpts) - start a new interface file
+# genOpts - GeneratorOptions controlling what's generated and how
+# endFile() - finish an interface file, closing it when done
+# beginFeature(interface, emit) - write interface for a feature
+# and tag generated features as having been done.
+# interface - element for the <version> / <extension> to generate
+# emit - actually write to the header only when True
+# endFeature() - finish an interface.
+# genType(typeinfo,name,alias) - generate interface for a type
+# typeinfo - TypeInfo for a type
+# genStruct(typeinfo,name,alias) - generate interface for a C "struct" type.
+# typeinfo - TypeInfo for a type interpreted as a struct
+# genGroup(groupinfo,name,alias) - generate interface for a group of enums (C "enum")
+# groupinfo - GroupInfo for a group
+# genEnum(enuminfo,name,alias) - generate interface for an enum (constant)
+# enuminfo - EnumInfo for an enum
+# name - enum name
+# genCmd(cmdinfo,name,alias) - generate interface for a command
+# cmdinfo - CmdInfo for a command
+# isEnumRequired(enumElem) - return True if this <enum> element is required
+# elem - <enum> element to test
+# makeCDecls(cmd) - return C prototype and function pointer typedef for a
+# <command> Element, as a list of two strings
+# cmd - Element for the <command>
+# newline() - print a newline to the output file (utility function)
+#
+class OutputGenerator:
+ """Generate specified API interfaces in a specific style, such as a C header"""
+ #
+ # categoryToPath - map XML 'category' to include file directory name
+ categoryToPath = {
+ 'bitmask' : 'flags',
+ 'enum' : 'enums',
+ 'funcpointer' : 'funcpointers',
+ 'handle' : 'handles',
+ 'define' : 'defines',
+ 'basetype' : 'basetypes',
+ }
+ #
+ # Constructor
+ def __init__(self,
+ errFile = sys.stderr,
+ warnFile = sys.stderr,
+ diagFile = sys.stdout):
+ self.outFile = None
+ self.errFile = errFile
+ self.warnFile = warnFile
+ self.diagFile = diagFile
+ # Internal state
+ self.featureName = None
+ self.genOpts = None
+ self.registry = None
+ # Used for extension enum value generation
+ self.extBase = 1000000000
+ self.extBlockSize = 1000
+ self.madeDirs = {}
+ #
+ # logMsg - write a message of different categories to different
+ # destinations.
+ # level -
+ # 'diag' (diagnostic, voluminous)
+ # 'warn' (warning)
+ # 'error' (fatal error - raises exception after logging)
+ # *args - print()-style arguments to direct to corresponding log
+ def logMsg(self, level, *args):
+ """Log a message at the given level. Can be ignored or log to a file"""
+ if (level == 'error'):
+ strfile = io.StringIO()
+ write('ERROR:', *args, file=strfile)
+ if (self.errFile != None):
+ write(strfile.getvalue(), file=self.errFile)
+ raise UserWarning(strfile.getvalue())
+ elif (level == 'warn'):
+ if (self.warnFile != None):
+ write('WARNING:', *args, file=self.warnFile)
+ elif (level == 'diag'):
+ if (self.diagFile != None):
+ write('DIAG:', *args, file=self.diagFile)
+ else:
+ raise UserWarning(
+ '*** FATAL ERROR in Generator.logMsg: unknown level:' + level)
+ #
+ # enumToValue - parses and converts an <enum> tag into a value.
+ # Returns a list
+ # first element - integer representation of the value, or None
+ # if needsNum is False. The value must be a legal number
+ # if needsNum is True.
+ # second element - string representation of the value
+ # There are several possible representations of values.
+ # A 'value' attribute simply contains the value.
+ # A 'bitpos' attribute defines a value by specifying the bit
+ # position which is set in that value.
+ # A 'offset','extbase','extends' triplet specifies a value
+ # as an offset to a base value defined by the specified
+ # 'extbase' extension name, which is then cast to the
+ # typename specified by 'extends'. This requires probing
+ # the registry database, and imbeds knowledge of the
+ # Vulkan extension enum scheme in this function.
+ # A 'alias' attribute contains the name of another enum
+ # which this is an alias of. The other enum must be
+ # declared first when emitting this enum.
+ def enumToValue(self, elem, needsNum):
+ name = elem.get('name')
+ numVal = None
+ if ('value' in elem.keys()):
+ value = elem.get('value')
+ # print('About to translate value =', value, 'type =', type(value))
+ if (needsNum):
+ numVal = int(value, 0)
+ # If there's a non-integer, numeric 'type' attribute (e.g. 'u' or
+ # 'ull'), append it to the string value.
+ # t = enuminfo.elem.get('type')
+ # if (t != None and t != '' and t != 'i' and t != 's'):
+ # value += enuminfo.type
+ self.logMsg('diag', 'Enum', name, '-> value [', numVal, ',', value, ']')
+ return [numVal, value]
+ if ('bitpos' in elem.keys()):
+ value = elem.get('bitpos')
+ numVal = int(value, 0)
+ numVal = 1 << numVal
+ value = '0x%08x' % numVal
+ self.logMsg('diag', 'Enum', name, '-> bitpos [', numVal, ',', value, ']')
+ return [numVal, value]
+ if ('offset' in elem.keys()):
+ # Obtain values in the mapping from the attributes
+ enumNegative = False
+ offset = int(elem.get('offset'),0)
+ extnumber = int(elem.get('extnumber'),0)
+ extends = elem.get('extends')
+ if ('dir' in elem.keys()):
+ enumNegative = True
+ self.logMsg('diag', 'Enum', name, 'offset =', offset,
+ 'extnumber =', extnumber, 'extends =', extends,
+ 'enumNegative =', enumNegative)
+ # Now determine the actual enumerant value, as defined
+ # in the "Layers and Extensions" appendix of the spec.
+ numVal = self.extBase + (extnumber - 1) * self.extBlockSize + offset
+ if (enumNegative):
+ numVal = -numVal
+ value = '%d' % numVal
+ # More logic needed!
+ self.logMsg('diag', 'Enum', name, '-> offset [', numVal, ',', value, ']')
+ return [numVal, value]
+ if 'alias' in elem.keys():
+ return [None, elem.get('alias')]
+ return [None, None]
+ #
+ # checkDuplicateEnums - sanity check for enumerated values
+ # enums - list of <enum> Elements
+ # returns the list with duplicates stripped
+ def checkDuplicateEnums(self, enums):
+ # Dictionaries indexed by name and numeric value.
+ # Entries are [ Element, numVal, strVal ] matching name or value
+
+ nameMap = {}
+ valueMap = {}
+
+ stripped = []
+ for elem in enums:
+ name = elem.get('name')
+ (numVal, strVal) = self.enumToValue(elem, True)
+
+ if name in nameMap:
+ # Duplicate name found; check values
+ (name2, numVal2, strVal2) = nameMap[name]
+
+ # Duplicate enum values for the same name are benign. This
+ # happens when defining the same enum conditionally in
+ # several extension blocks.
+ if (strVal2 == strVal or (numVal != None and
+ numVal == numVal2)):
+ True
+ # self.logMsg('info', 'checkDuplicateEnums: Duplicate enum (' + name +
+ # ') found with the same value:' + strVal)
+ else:
+ self.logMsg('warn', 'checkDuplicateEnums: Duplicate enum (' + name +
+ ') found with different values:' + strVal +
+ ' and ' + strVal2)
+
+ # Don't add the duplicate to the returned list
+ continue
+ elif numVal in valueMap:
+ # Duplicate value found (such as an alias); report it, but
+ # still add this enum to the list.
+ (name2, numVal2, strVal2) = valueMap[numVal]
+
+ try:
+ self.logMsg('warn', 'Two enums found with the same value: '
+ + name + ' = ' + name2.get('name') + ' = ' + strVal)
+ except:
+ pdb.set_trace()
+
+ # Track this enum to detect followon duplicates
+ nameMap[name] = [ elem, numVal, strVal ]
+ if numVal != None:
+ valueMap[numVal] = [ elem, numVal, strVal ]
+
+ # Add this enum to the list
+ stripped.append(elem)
+
+ # Return the list
+ return stripped
+ #
+ def makeDir(self, path):
+ self.logMsg('diag', 'OutputGenerator::makeDir(' + path + ')')
+ if not (path in self.madeDirs.keys()):
+ # This can get race conditions with multiple writers, see
+ # https://stackoverflow.com/questions/273192/
+ if not os.path.exists(path):
+ os.makedirs(path)
+ self.madeDirs[path] = None
+ #
+ def beginFile(self, genOpts):
+ self.genOpts = genOpts
+ #
+ # Open specified output file. Not done in constructor since a
+ # Generator can be used without writing to a file.
+ if (self.genOpts.filename != None):
+ filename = self.genOpts.directory + '/' + self.genOpts.filename
+ self.outFile = io.open(filename, 'w', encoding='utf-8')
+ else:
+ self.outFile = sys.stdout
+ def endFile(self):
+ self.errFile and self.errFile.flush()
+ self.warnFile and self.warnFile.flush()
+ self.diagFile and self.diagFile.flush()
+ self.outFile.flush()
+ if (self.outFile != sys.stdout and self.outFile != sys.stderr):
+ self.outFile.close()
+ self.genOpts = None
+ #
+ def beginFeature(self, interface, emit):
+ self.emit = emit
+ self.featureName = interface.get('name')
+ # If there's an additional 'protect' attribute in the feature, save it
+ self.featureExtraProtect = interface.get('protect')
+ def endFeature(self):
+ # Derived classes responsible for emitting feature
+ self.featureName = None
+ self.featureExtraProtect = None
+ # Utility method to validate we're generating something only inside a
+ # <feature> tag
+ def validateFeature(self, featureType, featureName):
+ if (self.featureName == None):
+ raise UserWarning('Attempt to generate', featureType,
+ featureName, 'when not in feature')
+ #
+ # Type generation
+ def genType(self, typeinfo, name, alias):
+ self.validateFeature('type', name)
+ #
+ # Struct (e.g. C "struct" type) generation
+ def genStruct(self, typeinfo, name, alias):
+ self.validateFeature('struct', name)
+
+ # The mixed-mode <member> tags may contain no-op <comment> tags.
+ # It is convenient to remove them here where all output generators
+ # will benefit.
+ for member in typeinfo.elem.findall('.//member'):
+ for comment in member.findall('comment'):
+ member.remove(comment)
+ #
+ # Group (e.g. C "enum" type) generation
+ def genGroup(self, groupinfo, name, alias):
+ self.validateFeature('group', name)
+ #
+ # Enumerant (really, constant) generation
+ def genEnum(self, enuminfo, name, alias):
+ self.validateFeature('enum', name)
+ #
+ # Command generation
+ def genCmd(self, cmd, name, alias):
+ self.validateFeature('command', name)
+ #
+ # Utility functions - turn a <proto> <name> into C-language prototype
+ # and typedef declarations for that name.
+ # name - contents of <name> tag
+ # tail - whatever text follows that tag in the Element
+ def makeProtoName(self, name, tail):
+ return self.genOpts.apientry + name + tail
+ def makeTypedefName(self, name, tail):
+ return '(' + self.genOpts.apientryp + 'PFN_' + name + tail + ')'
+ #
+ # makeCParamDecl - return a string which is an indented, formatted
+ # declaration for a <param> or <member> block (e.g. function parameter
+ # or structure/union member).
+ # param - Element (<param> or <member>) to format
+ # aligncol - if non-zero, attempt to align the nested <name> element
+ # at this column
+ def makeCParamDecl(self, param, aligncol):
+ paramdecl = ' ' + noneStr(param.text)
+ for elem in param:
+ text = noneStr(elem.text)
+ tail = noneStr(elem.tail)
+ if (elem.tag == 'name' and aligncol > 0):
+ self.logMsg('diag', 'Aligning parameter', elem.text, 'to column', self.genOpts.alignFuncParam)
+ # Align at specified column, if possible
+ paramdecl = paramdecl.rstrip()
+ oldLen = len(paramdecl)
+ # This works around a problem where very long type names -
+ # longer than the alignment column - would run into the tail
+ # text.
+ paramdecl = paramdecl.ljust(aligncol-1) + ' '
+ newLen = len(paramdecl)
+ self.logMsg('diag', 'Adjust length of parameter decl from', oldLen, 'to', newLen, ':', paramdecl)
+ paramdecl += text + tail
+ return paramdecl
+ #
+ # getCParamTypeLength - return the length of the type field is an indented, formatted
+ # declaration for a <param> or <member> block (e.g. function parameter
+ # or structure/union member).
+ # param - Element (<param> or <member>) to identify
+ def getCParamTypeLength(self, param):
+ paramdecl = ' ' + noneStr(param.text)
+ for elem in param:
+ text = noneStr(elem.text)
+ tail = noneStr(elem.tail)
+ if (elem.tag == 'name'):
+ # Align at specified column, if possible
+ newLen = len(paramdecl.rstrip())
+ self.logMsg('diag', 'Identifying length of', elem.text, 'as', newLen)
+ paramdecl += text + tail
+ return newLen
+ #
+ # isEnumRequired(elem) - return True if this <enum> element is
+ # required, False otherwise
+ # elem - <enum> element to test
+ def isEnumRequired(self, elem):
+ required = elem.get('required') != None
+ self.logMsg('diag', 'isEnumRequired:', elem.get('name'),
+ '->', required)
+ return required
+
+ #@@@ This code is overridden by equivalent code now run in
+ #@@@ Registry.generateFeature
+
+ required = False
+
+ extname = elem.get('extname')
+ if extname is not None:
+ # 'supported' attribute was injected when the <enum> element was
+ # moved into the <enums> group in Registry.parseTree()
+ if self.genOpts.defaultExtensions == elem.get('supported'):
+ required = True
+ elif re.match(self.genOpts.addExtensions, extname) is not None:
+ required = True
+ elif elem.get('version') is not None:
+ required = re.match(self.genOpts.emitversions, elem.get('version')) is not None
+ else:
+ required = True
+
+ return required
+
+ #
+ # makeCDecls - return C prototype and function pointer typedef for a
+ # command, as a two-element list of strings.
+ # cmd - Element containing a <command> tag
+ def makeCDecls(self, cmd):
+ """Generate C function pointer typedef for <command> Element"""
+ proto = cmd.find('proto')
+ params = cmd.findall('param')
+ # Begin accumulating prototype and typedef strings
+ pdecl = self.genOpts.apicall
+ tdecl = 'typedef '
+ #
+ # Insert the function return type/name.
+ # For prototypes, add APIENTRY macro before the name
+ # For typedefs, add (APIENTRY *<name>) around the name and
+ # use the PFN_cmdnameproc naming convention.
+ # Done by walking the tree for <proto> element by element.
+ # etree has elem.text followed by (elem[i], elem[i].tail)
+ # for each child element and any following text
+ # Leading text
+ pdecl += noneStr(proto.text)
+ tdecl += noneStr(proto.text)
+ # For each child element, if it's a <name> wrap in appropriate
+ # declaration. Otherwise append its contents and tail contents.
+ for elem in proto:
+ text = noneStr(elem.text)
+ tail = noneStr(elem.tail)
+ if (elem.tag == 'name'):
+ pdecl += self.makeProtoName(text, tail)
+ tdecl += self.makeTypedefName(text, tail)
+ else:
+ pdecl += text + tail
+ tdecl += text + tail
+ # Now add the parameter declaration list, which is identical
+ # for prototypes and typedefs. Concatenate all the text from
+ # a <param> node without the tags. No tree walking required
+ # since all tags are ignored.
+ # Uses: self.indentFuncProto
+ # self.indentFuncPointer
+ # self.alignFuncParam
+ # Might be able to doubly-nest the joins, e.g.
+ # ','.join(('_'.join([l[i] for i in range(0,len(l))])
+ n = len(params)
+ # Indented parameters
+ if n > 0:
+ indentdecl = '(\n'
+ for i in range(0,n):
+ paramdecl = self.makeCParamDecl(params[i], self.genOpts.alignFuncParam)
+ if (i < n - 1):
+ paramdecl += ',\n'
+ else:
+ paramdecl += ');'
+ indentdecl += paramdecl
+ else:
+ indentdecl = '(void);'
+ # Non-indented parameters
+ paramdecl = '('
+ if n > 0:
+ for i in range(0,n):
+ paramdecl += ''.join([t for t in params[i].itertext()])
+ if (i < n - 1):
+ paramdecl += ', '
+ else:
+ paramdecl += 'void'
+ paramdecl += ");";
+ return [ pdecl + indentdecl, tdecl + paramdecl ]
+ #
+ def newline(self):
+ write('', file=self.outFile)
+
+ def setRegistry(self, registry):
+ self.registry = registry
+ #
--- /dev/null
+#!/usr/bin/python3
+#
+# Copyright (c) 2013-2018 The Khronos Group 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.
+
+import argparse, cProfile, pdb, string, sys, time
+from reg import *
+from generator import write
+from cgenerator import CGeneratorOptions, COutputGenerator
+from docgenerator import DocGeneratorOptions, DocOutputGenerator
+from extensionmetadocgenerator import ExtensionMetaDocGeneratorOptions, ExtensionMetaDocOutputGenerator
+from pygenerator import PyOutputGenerator
+from validitygenerator import ValidityOutputGenerator
+from hostsyncgenerator import HostSynchronizationOutputGenerator
+from extensionStubSource import ExtensionStubSourceOutputGenerator
+
+# Simple timer functions
+startTime = None
+
+def startTimer(timeit):
+ global startTime
+ startTime = time.clock()
+
+def endTimer(timeit, msg):
+ global startTime
+ endTime = time.clock()
+ if (timeit):
+ write(msg, endTime - startTime, file=sys.stderr)
+ startTime = None
+
+# Turn a list of strings into a regexp string matching exactly those strings
+def makeREstring(list, default = None):
+ if len(list) > 0 or default == None:
+ return '^(' + '|'.join(list) + ')$'
+ else:
+ return default
+
+# Returns a directory of [ generator function, generator options ] indexed
+# by specified short names. The generator options incorporate the following
+# parameters:
+#
+# args is an parsed argument object; see below for the fields that are used.
+def makeGenOpts(args):
+ global genOpts
+ genOpts = {}
+
+ # Default class of extensions to include, or None
+ defaultExtensions = args.defaultExtensions
+
+ # Additional extensions to include (list of extensions)
+ extensions = args.extension
+
+ # Extensions to remove (list of extensions)
+ removeExtensions = args.removeExtensions
+
+ # Extensions to emit (list of extensions)
+ emitExtensions = args.emitExtensions
+
+ # Features to include (list of features)
+ features = args.feature
+
+ # Whether to disable inclusion protect in headers
+ protect = args.protect
+
+ # Output target directory
+ directory = args.directory
+
+ # Descriptive names for various regexp patterns used to select
+ # versions and extensions
+ allFeatures = allExtensions = '.*'
+ noFeatures = noExtensions = None
+
+ # Turn lists of names/patterns into matching regular expressions
+ addExtensionsPat = makeREstring(extensions, None)
+ removeExtensionsPat = makeREstring(removeExtensions, None)
+ emitExtensionsPat = makeREstring(emitExtensions, allExtensions)
+ featuresPat = makeREstring(features, allFeatures)
+
+ # Copyright text prefixing all headers (list of strings).
+ prefixStrings = [
+ '/*',
+ '** Copyright (c) 2015-2018 The Khronos Group 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.',
+ '*/',
+ ''
+ ]
+
+ # Text specific to Vulkan headers
+ vkPrefixStrings = [
+ '/*',
+ '** This header is generated from the Khronos Vulkan XML API Registry.',
+ '**',
+ '*/',
+ ''
+ ]
+
+ # Defaults for generating re-inclusion protection wrappers (or not)
+ protectFile = protect
+ protectFeature = protect
+ protectProto = protect
+
+ # API include files for spec and ref pages
+ # Overwrites include subdirectories in spec source tree
+ # The generated include files do not include the calling convention
+ # macros (apientry etc.), unlike the header files.
+ # Because the 1.0 core branch includes ref pages for extensions,
+ # all the extension interfaces need to be generated, even though
+ # none are used by the core spec itself.
+ genOpts['apiinc'] = [
+ DocOutputGenerator,
+ DocGeneratorOptions(
+ filename = 'timeMarker',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = featuresPat,
+ defaultExtensions = None,
+ addExtensions = addExtensionsPat,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat,
+ prefixText = prefixStrings + vkPrefixStrings,
+ apicall = '',
+ apientry = '',
+ apientryp = '*',
+ alignFuncParam = 48,
+ expandEnumerants = False)
+ ]
+
+ # API names to validate man/api spec includes & links
+ genOpts['vkapi.py'] = [
+ PyOutputGenerator,
+ DocGeneratorOptions(
+ filename = 'vkapi.py',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = featuresPat,
+ defaultExtensions = None,
+ addExtensions = addExtensionsPat,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat)
+ ]
+
+ # API validity files for spec
+ genOpts['validinc'] = [
+ ValidityOutputGenerator,
+ DocGeneratorOptions(
+ filename = 'timeMarker',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = featuresPat,
+ defaultExtensions = None,
+ addExtensions = addExtensionsPat,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat)
+ ]
+
+ # API host sync table files for spec
+ genOpts['hostsyncinc'] = [
+ HostSynchronizationOutputGenerator,
+ DocGeneratorOptions(
+ filename = 'timeMarker',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = featuresPat,
+ defaultExtensions = None,
+ addExtensions = addExtensionsPat,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat)
+ ]
+
+ # Extension stub source dispatcher
+ genOpts['vulkan_ext.c'] = [
+ ExtensionStubSourceOutputGenerator,
+ CGeneratorOptions(
+ filename = 'vulkan_ext.c',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = None,
+ defaultExtensions = None,
+ addExtensions = '.*',
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat,
+ prefixText = prefixStrings + vkPrefixStrings,
+ alignFuncParam = 48)
+ ]
+
+ # Extension metainformation for spec extension appendices
+ genOpts['extinc'] = [
+ ExtensionMetaDocOutputGenerator,
+ ExtensionMetaDocGeneratorOptions(
+ filename = 'timeMarker',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = None,
+ defaultExtensions = defaultExtensions,
+ addExtensions = None,
+ removeExtensions = None,
+ emitExtensions = emitExtensionsPat)
+ ]
+
+ # Platform extensions, in their own header files
+ # Each element of the platforms[] array defines information for
+ # generating a single platform:
+ # [0] is the generated header file name
+ # [1] is the set of platform extensions to generate
+ # [2] is additional extensions whose interfaces should be considered,
+ # but suppressed in the output, to avoid duplicate definitions of
+ # dependent types like VkDisplayKHR and VkSurfaceKHR which come from
+ # non-platform extensions.
+
+ # Track all platform extensions, for exclusion from vulkan_core.h
+ allPlatformExtensions = []
+
+ # Extensions suppressed for all platforms.
+ # Covers common WSI extension types.
+ commonSuppressExtensions = [ 'VK_KHR_display', 'VK_KHR_swapchain' ]
+
+ platforms = [
+ [ 'vulkan_android.h', [ 'VK_KHR_android_surface',
+ 'VK_ANDROID_external_memory_android_hardware_buffer'
+ ], commonSuppressExtensions ],
+ [ 'vulkan_ios.h', [ 'VK_MVK_ios_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_macos.h', [ 'VK_MVK_macos_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_mir.h', [ 'VK_KHR_mir_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_vi.h', [ 'VK_NN_vi_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_wayland.h', [ 'VK_KHR_wayland_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_win32.h', [ 'VK_.*_win32(|_.*)' ], commonSuppressExtensions + [ 'VK_KHR_external_semaphore', 'VK_KHR_external_memory_capabilities', 'VK_KHR_external_fence', 'VK_KHR_external_fence_capabilities', 'VK_NV_external_memory_capabilities' ] ],
+ [ 'vulkan_xcb.h', [ 'VK_KHR_xcb_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_xlib.h', [ 'VK_KHR_xlib_surface' ], commonSuppressExtensions ],
+ [ 'vulkan_xlib_xrandr.h', [ 'VK_EXT_acquire_xlib_display' ], commonSuppressExtensions ],
+ ]
+
+ for platform in platforms:
+ headername = platform[0]
+
+ allPlatformExtensions += platform[1]
+
+ addPlatformExtensionsRE = makeREstring(platform[1] + platform[2])
+ emitPlatformExtensionsRE = makeREstring(platform[1])
+
+ opts = CGeneratorOptions(
+ filename = headername,
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = None,
+ defaultExtensions = None,
+ addExtensions = addPlatformExtensionsRE,
+ removeExtensions = None,
+ emitExtensions = emitPlatformExtensionsRE,
+ prefixText = prefixStrings + vkPrefixStrings,
+ genFuncPointers = True,
+ protectFile = protectFile,
+ protectFeature = False,
+ protectProto = '#ifndef',
+ protectProtoStr = 'VK_NO_PROTOTYPES',
+ apicall = 'VKAPI_ATTR ',
+ apientry = 'VKAPI_CALL ',
+ apientryp = 'VKAPI_PTR *',
+ alignFuncParam = 48)
+
+ genOpts[headername] = [ COutputGenerator, opts ]
+
+ # Header for core API + extensions.
+ # To generate just the core API,
+ # change to 'defaultExtensions = None' below.
+ #
+ # By default this adds all enabled, non-platform extensions.
+ # It removes all platform extensions (from the platform headers options
+ # constructed above) as well as any explicitly specified removals.
+
+ removeExtensionsPat = makeREstring(allPlatformExtensions + removeExtensions, None)
+
+ genOpts['vulkan_core.h'] = [
+ COutputGenerator,
+ CGeneratorOptions(
+ filename = 'vulkan_core.h',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = featuresPat,
+ defaultExtensions = defaultExtensions,
+ addExtensions = None,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat,
+ prefixText = prefixStrings + vkPrefixStrings,
+ genFuncPointers = True,
+ protectFile = protectFile,
+ protectFeature = False,
+ protectProto = '#ifndef',
+ protectProtoStr = 'VK_NO_PROTOTYPES',
+ apicall = 'VKAPI_ATTR ',
+ apientry = 'VKAPI_CALL ',
+ apientryp = 'VKAPI_PTR *',
+ alignFuncParam = 48)
+ ]
+
+ # Unused - vulkan10.h target.
+ # It is possible to generate a header with just the Vulkan 1.0 +
+ # extension interfaces defined, but since the promoted KHR extensions
+ # are now defined in terms of the 1.1 interfaces, such a header is very
+ # similar to vulkan_core.h.
+ genOpts['vulkan10.h'] = [
+ COutputGenerator,
+ CGeneratorOptions(
+ filename = 'vulkan10.h',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = 'VK_VERSION_1_0',
+ emitversions = 'VK_VERSION_1_0',
+ defaultExtensions = defaultExtensions,
+ addExtensions = None,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat,
+ prefixText = prefixStrings + vkPrefixStrings,
+ genFuncPointers = True,
+ protectFile = protectFile,
+ protectFeature = False,
+ protectProto = '#ifndef',
+ protectProtoStr = 'VK_NO_PROTOTYPES',
+ apicall = 'VKAPI_ATTR ',
+ apientry = 'VKAPI_CALL ',
+ apientryp = 'VKAPI_PTR *',
+ alignFuncParam = 48)
+ ]
+
+ genOpts['alias.h'] = [
+ COutputGenerator,
+ CGeneratorOptions(
+ filename = 'alias.h',
+ directory = directory,
+ apiname = 'vulkan',
+ profile = None,
+ versions = featuresPat,
+ emitversions = featuresPat,
+ defaultExtensions = defaultExtensions,
+ addExtensions = None,
+ removeExtensions = removeExtensionsPat,
+ emitExtensions = emitExtensionsPat,
+ prefixText = None,
+ genFuncPointers = False,
+ protectFile = False,
+ protectFeature = False,
+ protectProto = '',
+ protectProtoStr = '',
+ apicall = '',
+ apientry = '',
+ apientryp = '',
+ alignFuncParam = 36)
+ ]
+
+# Generate a target based on the options in the matching genOpts{} object.
+# This is encapsulated in a function so it can be profiled and/or timed.
+# The args parameter is an parsed argument object containing the following
+# fields that are used:
+# target - target to generate
+# directory - directory to generate it in
+# protect - True if re-inclusion wrappers should be created
+# extensions - list of additional extensions to include in generated
+# interfaces
+def genTarget(args):
+ global genOpts
+
+ # Create generator options with specified parameters
+ makeGenOpts(args)
+
+ if (args.target in genOpts.keys()):
+ createGenerator = genOpts[args.target][0]
+ options = genOpts[args.target][1]
+
+ if not args.quiet:
+ write('* Building', options.filename, file=sys.stderr)
+ write('* options.versions =', options.versions, file=sys.stderr)
+ write('* options.emitversions =', options.emitversions, file=sys.stderr)
+ write('* options.defaultExtensions =', options.defaultExtensions, file=sys.stderr)
+ write('* options.addExtensions =', options.addExtensions, file=sys.stderr)
+ write('* options.removeExtensions =', options.removeExtensions, file=sys.stderr)
+ write('* options.emitExtensions =', options.emitExtensions, file=sys.stderr)
+
+ startTimer(args.time)
+ gen = createGenerator(errFile=errWarn,
+ warnFile=errWarn,
+ diagFile=diag)
+ reg.setGenerator(gen)
+ reg.apiGen(options)
+
+ if not args.quiet:
+ write('* Generated', options.filename, file=sys.stderr)
+ endTimer(args.time, '* Time to generate ' + options.filename + ' =')
+ else:
+ write('No generator options for unknown target:',
+ args.target, file=sys.stderr)
+
+# -feature name
+# -extension name
+# For both, "name" may be a single name, or a space-separated list
+# of names, or a regular expression.
+if __name__ == '__main__':
+ parser = argparse.ArgumentParser()
+
+ parser.add_argument('-defaultExtensions', action='store',
+ default='vulkan',
+ help='Specify a single class of extensions to add to targets')
+ parser.add_argument('-extension', action='append',
+ default=[],
+ help='Specify an extension or extensions to add to targets')
+ parser.add_argument('-removeExtensions', action='append',
+ default=[],
+ help='Specify an extension or extensions to remove from targets')
+ parser.add_argument('-emitExtensions', action='append',
+ default=[],
+ help='Specify an extension or extensions to emit in targets')
+ parser.add_argument('-feature', action='append',
+ default=[],
+ help='Specify a core API feature name or names to add to targets')
+ parser.add_argument('-debug', action='store_true',
+ help='Enable debugging')
+ parser.add_argument('-dump', action='store_true',
+ help='Enable dump to stderr')
+ parser.add_argument('-diagfile', action='store',
+ default=None,
+ help='Write diagnostics to specified file')
+ parser.add_argument('-errfile', action='store',
+ default=None,
+ help='Write errors and warnings to specified file instead of stderr')
+ parser.add_argument('-noprotect', dest='protect', action='store_false',
+ help='Disable inclusion protection in output headers')
+ parser.add_argument('-profile', action='store_true',
+ help='Enable profiling')
+ parser.add_argument('-registry', action='store',
+ default='vk.xml',
+ help='Use specified registry file instead of vk.xml')
+ parser.add_argument('-time', action='store_true',
+ help='Enable timing')
+ parser.add_argument('-validate', action='store_true',
+ help='Enable group validation')
+ parser.add_argument('-o', action='store', dest='directory',
+ default='.',
+ help='Create target and related files in specified directory')
+ parser.add_argument('target', metavar='target', nargs='?',
+ help='Specify target')
+ parser.add_argument('-quiet', action='store_true', default=True,
+ help='Suppress script output during normal execution.')
+ parser.add_argument('-verbose', action='store_false', dest='quiet', default=True,
+ help='Enable script output during normal execution.')
+
+ args = parser.parse_args()
+
+ # This splits arguments which are space-separated lists
+ args.feature = [name for arg in args.feature for name in arg.split()]
+ args.extension = [name for arg in args.extension for name in arg.split()]
+
+ # Load & parse registry
+ reg = Registry()
+
+ startTimer(args.time)
+ tree = etree.parse(args.registry)
+ endTimer(args.time, '* Time to make ElementTree =')
+
+ if args.debug:
+ pdb.run('reg.loadElementTree(tree)')
+ else:
+ startTimer(args.time)
+ reg.loadElementTree(tree)
+ endTimer(args.time, '* Time to parse ElementTree =')
+
+ if (args.validate):
+ reg.validateGroups()
+
+ if (args.dump):
+ write('* Dumping registry to regdump.txt', file=sys.stderr)
+ reg.dumpReg(filehandle = open('regdump.txt', 'w', encoding='utf-8'))
+
+ # create error/warning & diagnostic files
+ if (args.errfile):
+ errWarn = open(args.errfile, 'w', encoding='utf-8')
+ else:
+ errWarn = sys.stderr
+
+ if (args.diagfile):
+ diag = open(args.diagfile, 'w', encoding='utf-8')
+ else:
+ diag = None
+
+ if (args.debug):
+ pdb.run('genTarget(args)')
+ elif (args.profile):
+ import cProfile, pstats
+ cProfile.run('genTarget(args)', 'profile.txt')
+ p = pstats.Stats('profile.txt')
+ p.strip_dirs().sort_stats('time').print_stats(50)
+ else:
+ genTarget(args)
--- /dev/null
+#!/usr/bin/python3 -i
+#
+# Copyright (c) 2013-2018 The Khronos Group 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.
+
+import io,os,pdb,re,string,sys,copy
+import xml.etree.ElementTree as etree
+from collections import defaultdict
+
+# matchAPIProfile - returns whether an API and profile
+# being generated matches an element's profile
+# api - string naming the API to match
+# profile - string naming the profile to match
+# elem - Element which (may) have 'api' and 'profile'
+# attributes to match to.
+# If a tag is not present in the Element, the corresponding API
+# or profile always matches.
+# Otherwise, the tag must exactly match the API or profile.
+# Thus, if 'profile' = core:
+# <remove> with no attribute will match
+# <remove profile='core'> will match
+# <remove profile='compatibility'> will not match
+# Possible match conditions:
+# Requested Element
+# Profile Profile
+# --------- --------
+# None None Always matches
+# 'string' None Always matches
+# None 'string' Does not match. Can't generate multiple APIs
+# or profiles, so if an API/profile constraint
+# is present, it must be asked for explicitly.
+# 'string' 'string' Strings must match
+#
+# ** In the future, we will allow regexes for the attributes,
+# not just strings, so that api="^(gl|gles2)" will match. Even
+# this isn't really quite enough, we might prefer something
+# like "gl(core)|gles1(common-lite)".
+def matchAPIProfile(api, profile, elem):
+ """Match a requested API & profile name to a api & profile attributes of an Element"""
+ match = True
+ # Match 'api', if present
+ if ('api' in elem.attrib):
+ if (api == None):
+ raise UserWarning("No API requested, but 'api' attribute is present with value '" +
+ elem.get('api') + "'")
+ elif (api != elem.get('api')):
+ # Requested API doesn't match attribute
+ return False
+ if ('profile' in elem.attrib):
+ if (profile == None):
+ raise UserWarning("No profile requested, but 'profile' attribute is present with value '" +
+ elem.get('profile') + "'")
+ elif (profile != elem.get('profile')):
+ # Requested profile doesn't match attribute
+ return False
+ return True
+
+# BaseInfo - base class for information about a registry feature
+# (type/group/enum/command/API/extension).
+# required - should this feature be defined during header generation
+# (has it been removed by a profile or version)?
+# declared - has this feature been defined already?
+# elem - etree Element for this feature
+# resetState() - reset required/declared to initial values. Used
+# prior to generating a new API interface.
+# compareElem(info) - return True if self.elem and info.elem have the
+# same definition.
+class BaseInfo:
+ """Represents the state of a registry feature, used during API generation"""
+ def __init__(self, elem):
+ self.required = False
+ self.declared = False
+ self.elem = elem
+ def resetState(self):
+ self.required = False
+ self.declared = False
+ def compareElem(self, info):
+ # Just compares the tag and attributes.
+ # @@ This should be virtualized. In particular, comparing <enum>
+ # tags requires special-casing on the attributes, as 'extnumber' is
+ # only relevant when 'offset' is present.
+ selfKeys = sorted(self.elem.keys())
+ infoKeys = sorted(info.elem.keys())
+
+ if selfKeys != infoKeys:
+ return False
+
+ # Ignore value of 'extname', as this will inherently be different
+ # when redefining the same interface in different feature and/or
+ # extension blocks.
+ for key in selfKeys:
+ if (key != 'extname' and
+ (self.elem.get(key) != info.elem.get(key))):
+ return False
+
+ return True
+
+# TypeInfo - registry information about a type. No additional state
+# beyond BaseInfo is required.
+class TypeInfo(BaseInfo):
+ """Represents the state of a registry type"""
+ def __init__(self, elem):
+ BaseInfo.__init__(self, elem)
+ self.additionalValidity = []
+ self.removedValidity = []
+ def resetState(self):
+ BaseInfo.resetState(self)
+ self.additionalValidity = []
+ self.removedValidity = []
+
+# GroupInfo - registry information about a group of related enums
+# in an <enums> block, generally corresponding to a C "enum" type.
+class GroupInfo(BaseInfo):
+ """Represents the state of a registry <enums> group"""
+ def __init__(self, elem):
+ BaseInfo.__init__(self, elem)
+
+# EnumInfo - registry information about an enum
+# type - numeric type of the value of the <enum> tag
+# ( '' for GLint, 'u' for GLuint, 'ull' for GLuint64 )
+class EnumInfo(BaseInfo):
+ """Represents the state of a registry enum"""
+ def __init__(self, elem):
+ BaseInfo.__init__(self, elem)
+ self.type = elem.get('type')
+ if (self.type == None):
+ self.type = ''
+
+# CmdInfo - registry information about a command
+class CmdInfo(BaseInfo):
+ """Represents the state of a registry command"""
+ def __init__(self, elem):
+ BaseInfo.__init__(self, elem)
+ self.additionalValidity = []
+ self.removedValidity = []
+ def resetState(self):
+ BaseInfo.resetState(self)
+ self.additionalValidity = []
+ self.removedValidity = []
+
+# FeatureInfo - registry information about an API <feature>
+# or <extension>
+# name - feature name string (e.g. 'VK_KHR_surface')
+# version - feature version number (e.g. 1.2). <extension>
+# features are unversioned and assigned version number 0.
+# ** This is confusingly taken from the 'number' attribute of <feature>.
+# Needs fixing.
+# number - extension number, used for ordering and for
+# assigning enumerant offsets. <feature> features do
+# not have extension numbers and are assigned number 0.
+# category - category, e.g. VERSION or khr/vendor tag
+# emit - has this feature been defined already?
+class FeatureInfo(BaseInfo):
+ """Represents the state of an API feature (version/extension)"""
+ def __init__(self, elem):
+ BaseInfo.__init__(self, elem)
+ self.name = elem.get('name')
+ # Determine element category (vendor). Only works
+ # for <extension> elements.
+ if (elem.tag == 'feature'):
+ self.category = 'VERSION'
+ self.version = elem.get('name')
+ self.versionNumber = elem.get('number')
+ self.number = "0"
+ self.supported = None
+ else:
+ self.category = self.name.split('_', 2)[1]
+ self.version = "0"
+ self.versionNumber = "0"
+ self.number = elem.get('number')
+ self.supported = elem.get('supported')
+ self.emit = False
+
+from generator import write, GeneratorOptions, OutputGenerator
+
+# Registry - object representing an API registry, loaded from an XML file
+# Members
+# tree - ElementTree containing the root <registry>
+# typedict - dictionary of TypeInfo objects keyed by type name
+# groupdict - dictionary of GroupInfo objects keyed by group name
+# enumdict - dictionary of EnumInfo objects keyed by enum name
+# cmddict - dictionary of CmdInfo objects keyed by command name
+# apidict - dictionary of <api> Elements keyed by API name
+# extensions - list of <extension> Elements
+# extdict - dictionary of <extension> Elements keyed by extension name
+# gen - OutputGenerator object used to write headers / messages
+# genOpts - GeneratorOptions object used to control which
+# fetures to write and how to format them
+# emitFeatures - True to actually emit features for a version / extension,
+# or False to just treat them as emitted
+# breakPat - regexp pattern to break on when generatng names
+# Public methods
+# loadElementTree(etree) - load registry from specified ElementTree
+# loadFile(filename) - load registry from XML file
+# setGenerator(gen) - OutputGenerator to use
+# breakOnName() - specify a feature name regexp to break on when
+# generating features.
+# parseTree() - parse the registry once loaded & create dictionaries
+# dumpReg(maxlen, filehandle) - diagnostic to dump the dictionaries
+# to specified file handle (default stdout). Truncates type /
+# enum / command elements to maxlen characters (default 80)
+# generator(g) - specify the output generator object
+# apiGen(apiname, genOpts) - generate API headers for the API type
+# and profile specified in genOpts, but only for the versions and
+# extensions specified there.
+# apiReset() - call between calls to apiGen() to reset internal state
+# Private methods
+# addElementInfo(elem,info,infoName,dictionary) - add feature info to dict
+# lookupElementInfo(fname,dictionary) - lookup feature info in dict
+class Registry:
+ """Represents an API registry loaded from XML"""
+ def __init__(self):
+ self.tree = None
+ self.typedict = {}
+ self.groupdict = {}
+ self.enumdict = {}
+ self.cmddict = {}
+ self.apidict = {}
+ self.extensions = []
+ self.requiredextensions = [] # Hack - can remove it after validity generator goes away
+ self.validextensionstructs = defaultdict(list)
+ self.extdict = {}
+ # A default output generator, so commands prior to apiGen can report
+ # errors via the generator object.
+ self.gen = OutputGenerator()
+ self.genOpts = None
+ self.emitFeatures = False
+ self.breakPat = None
+ # self.breakPat = re.compile('VkFenceImportFlagBits.*')
+ def loadElementTree(self, tree):
+ """Load ElementTree into a Registry object and parse it"""
+ self.tree = tree
+ self.parseTree()
+ def loadFile(self, file):
+ """Load an API registry XML file into a Registry object and parse it"""
+ self.tree = etree.parse(file)
+ self.parseTree()
+ def setGenerator(self, gen):
+ """Specify output generator object. None restores the default generator"""
+ self.gen = gen
+ self.gen.setRegistry(self)
+
+ # addElementInfo - add information about an element to the
+ # corresponding dictionary
+ # elem - <type>/<enums>/<enum>/<command>/<feature>/<extension> Element
+ # info - corresponding {Type|Group|Enum|Cmd|Feature}Info object
+ # infoName - 'type' / 'group' / 'enum' / 'command' / 'feature' / 'extension'
+ # dictionary - self.{type|group|enum|cmd|api|ext}dict
+ # If the Element has an 'api' attribute, the dictionary key is the
+ # tuple (name,api). If not, the key is the name. 'name' is an
+ # attribute of the Element
+ def addElementInfo(self, elem, info, infoName, dictionary):
+ # self.gen.logMsg('diag', 'Adding ElementInfo.required =',
+ # info.required, 'name =', elem.get('name'))
+
+ if ('api' in elem.attrib):
+ key = (elem.get('name'),elem.get('api'))
+ else:
+ key = elem.get('name')
+ if key in dictionary:
+ if not dictionary[key].compareElem(info):
+ self.gen.logMsg('warn', 'Attempt to redefine', key,
+ 'with different value (this may be benign)')
+ #else:
+ # self.gen.logMsg('warn', 'Benign redefinition of', key,
+ # 'with identical value')
+ else:
+ dictionary[key] = info
+ #
+ # lookupElementInfo - find a {Type|Enum|Cmd}Info object by name.
+ # If an object qualified by API name exists, use that.
+ # fname - name of type / enum / command
+ # dictionary - self.{type|enum|cmd}dict
+ def lookupElementInfo(self, fname, dictionary):
+ key = (fname, self.genOpts.apiname)
+ if (key in dictionary):
+ # self.gen.logMsg('diag', 'Found API-specific element for feature', fname)
+ return dictionary[key]
+ elif (fname in dictionary):
+ # self.gen.logMsg('diag', 'Found generic element for feature', fname)
+ return dictionary[fname]
+ else:
+ return None
+ def breakOnName(self, regexp):
+ self.breakPat = re.compile(regexp)
+ def parseTree(self):
+ """Parse the registry Element, once created"""
+ # This must be the Element for the root <registry>
+ self.reg = self.tree.getroot()
+ #
+ # Create dictionary of registry types from toplevel <types> tags
+ # and add 'name' attribute to each <type> tag (where missing)
+ # based on its <name> element.
+ #
+ # There's usually one <types> block; more are OK
+ # Required <type> attributes: 'name' or nested <name> tag contents
+ self.typedict = {}
+ for type in self.reg.findall('types/type'):
+ # If the <type> doesn't already have a 'name' attribute, set
+ # it from contents of its <name> tag.
+ if (type.get('name') == None):
+ type.attrib['name'] = type.find('name').text
+ self.addElementInfo(type, TypeInfo(type), 'type', self.typedict)
+ #
+ # Create dictionary of registry enum groups from <enums> tags.
+ #
+ # Required <enums> attributes: 'name'. If no name is given, one is
+ # generated, but that group can't be identified and turned into an
+ # enum type definition - it's just a container for <enum> tags.
+ self.groupdict = {}
+ for group in self.reg.findall('enums'):
+ self.addElementInfo(group, GroupInfo(group), 'group', self.groupdict)
+ #
+ # Create dictionary of registry enums from <enum> tags
+ #
+ # <enums> tags usually define different namespaces for the values
+ # defined in those tags, but the actual names all share the
+ # same dictionary.
+ # Required <enum> attributes: 'name', 'value'
+ # For containing <enums> which have type="enum" or type="bitmask",
+ # tag all contained <enum>s are required. This is a stopgap until
+ # a better scheme for tagging core and extension enums is created.
+ self.enumdict = {}
+ for enums in self.reg.findall('enums'):
+ required = (enums.get('type') != None)
+ for enum in enums.findall('enum'):
+ enumInfo = EnumInfo(enum)
+ enumInfo.required = required
+ self.addElementInfo(enum, enumInfo, 'enum', self.enumdict)
+ # self.gen.logMsg('diag', 'parseTree: marked req =',
+ # required, 'for', enum.get('name'))
+ #
+ # Create dictionary of registry commands from <command> tags
+ # and add 'name' attribute to each <command> tag (where missing)
+ # based on its <proto><name> element.
+ #
+ # There's usually only one <commands> block; more are OK.
+ # Required <command> attributes: 'name' or <proto><name> tag contents
+ self.cmddict = {}
+ # List of commands which alias others. Contains
+ # [ aliasName, element ]
+ # for each alias
+ cmdAlias = []
+ for cmd in self.reg.findall('commands/command'):
+ # If the <command> doesn't already have a 'name' attribute, set
+ # it from contents of its <proto><name> tag.
+ name = cmd.get('name')
+ if name == None:
+ name = cmd.attrib['name'] = cmd.find('proto/name').text
+ ci = CmdInfo(cmd)
+ self.addElementInfo(cmd, ci, 'command', self.cmddict)
+ alias = cmd.get('alias')
+ if alias:
+ cmdAlias.append([name, alias, cmd])
+ # Now loop over aliases, injecting a copy of the aliased command's
+ # Element with the aliased prototype name replaced with the command
+ # name - if it exists.
+ for (name, alias, cmd) in cmdAlias:
+ if alias in self.cmddict:
+ #@ pdb.set_trace()
+ aliasInfo = self.cmddict[alias]
+ cmdElem = copy.deepcopy(aliasInfo.elem)
+ cmdElem.find('proto/name').text = name
+ cmdElem.attrib['name'] = name
+ cmdElem.attrib['alias'] = alias
+ ci = CmdInfo(cmdElem)
+ # Replace the dictionary entry for the CmdInfo element
+ self.cmddict[name] = ci
+
+ #@ newString = etree.tostring(base, encoding="unicode").replace(aliasValue, aliasName)
+ #@elem.append(etree.fromstring(replacement))
+ else:
+ self.gen.logMsg('warn', 'No matching <command> found for command',
+ cmd.get('name'), 'alias', alias)
+
+ #
+ # Create dictionaries of API and extension interfaces
+ # from toplevel <api> and <extension> tags.
+ #
+ self.apidict = {}
+ for feature in self.reg.findall('feature'):
+ featureInfo = FeatureInfo(feature)
+ self.addElementInfo(feature, featureInfo, 'feature', self.apidict)
+
+ # Add additional enums defined only in <feature> tags
+ # to the corresponding core type.
+ # When seen here, the <enum> element, processed to contain the
+ # numeric enum value, is added to the corresponding <enums>
+ # element, as well as adding to the enum dictionary. It is
+ # *removed* from the <require> element it is introduced in.
+ # Not doing this will cause spurious genEnum()
+ # calls to be made in output generation, and it's easier
+ # to handle here than in genEnum().
+ #
+ # In lxml.etree, an Element can have only one parent, so the
+ # append() operation also removes the element. But in Python's
+ # ElementTree package, an Element can have multiple parents. So
+ # it must be explicitly removed from the <require> tag, leading
+ # to the nested loop traversal of <require>/<enum> elements
+ # below.
+ #
+ # This code also adds a 'version' attribute containing the
+ # api version.
+ #
+ # For <enum> tags which are actually just constants, if there's
+ # no 'extends' tag but there is a 'value' or 'bitpos' tag, just
+ # add an EnumInfo record to the dictionary. That works because
+ # output generation of constants is purely dependency-based, and
+ # doesn't need to iterate through the XML tags.
+ #
+ for elem in feature.findall('require'):
+ for enum in elem.findall('enum'):
+ addEnumInfo = False
+ groupName = enum.get('extends')
+ if (groupName != None):
+ # self.gen.logMsg('diag', 'Found extension enum',
+ # enum.get('name'))
+ # Add version number attribute to the <enum> element
+ enum.attrib['version'] = featureInfo.version
+ # Look up the GroupInfo with matching groupName
+ if (groupName in self.groupdict.keys()):
+ # self.gen.logMsg('diag', 'Matching group',
+ # groupName, 'found, adding element...')
+ gi = self.groupdict[groupName]
+ gi.elem.append(enum)
+ # Remove element from parent <require> tag
+ # This should be a no-op in lxml.etree
+ elem.remove(enum)
+ else:
+ self.gen.logMsg('warn', 'NO matching group',
+ groupName, 'for enum', enum.get('name'), 'found.')
+ addEnumInfo = True
+ elif (enum.get('value') or enum.get('bitpos') or enum.get('alias')):
+ # self.gen.logMsg('diag', 'Adding extension constant "enum"',
+ # enum.get('name'))
+ addEnumInfo = True
+ if (addEnumInfo):
+ enumInfo = EnumInfo(enum)
+ self.addElementInfo(enum, enumInfo, 'enum', self.enumdict)
+
+ self.extensions = self.reg.findall('extensions/extension')
+ self.extdict = {}
+ for feature in self.extensions:
+ featureInfo = FeatureInfo(feature)
+ self.addElementInfo(feature, featureInfo, 'extension', self.extdict)
+
+ # Add additional enums defined only in <extension> tags
+ # to the corresponding core type.
+ # Algorithm matches that of enums in a "feature" tag as above.
+ #
+ # This code also adds a 'extnumber' attribute containing the
+ # extension number, used for enumerant value calculation.
+ #
+ for elem in feature.findall('require'):
+ for enum in elem.findall('enum'):
+ addEnumInfo = False
+ groupName = enum.get('extends')
+ if (groupName != None):
+ # self.gen.logMsg('diag', 'Found extension enum',
+ # enum.get('name'))
+
+ # Add <extension> block's extension number attribute to
+ # the <enum> element unless specified explicitly, such
+ # as when redefining an enum in another extension.
+ extnumber = enum.get('extnumber')
+ if not extnumber:
+ enum.attrib['extnumber'] = featureInfo.number
+
+ enum.attrib['extname'] = featureInfo.name
+ enum.attrib['supported'] = featureInfo.supported
+ # Look up the GroupInfo with matching groupName
+ if (groupName in self.groupdict.keys()):
+ # self.gen.logMsg('diag', 'Matching group',
+ # groupName, 'found, adding element...')
+ gi = self.groupdict[groupName]
+ gi.elem.append(enum)
+ # Remove element from parent <require> tag
+ # This should be a no-op in lxml.etree
+ elem.remove(enum)
+ else:
+ self.gen.logMsg('warn', 'NO matching group',
+ groupName, 'for enum', enum.get('name'), 'found.')
+ addEnumInfo = True
+ elif (enum.get('value') or enum.get('bitpos') or enum.get('alias')):
+ # self.gen.logMsg('diag', 'Adding extension constant "enum"',
+ # enum.get('name'))
+ addEnumInfo = True
+ if (addEnumInfo):
+ enumInfo = EnumInfo(enum)
+ self.addElementInfo(enum, enumInfo, 'enum', self.enumdict)
+
+ # Construct a "validextensionstructs" list for parent structures
+ # based on "structextends" tags in child structures
+ for type in self.reg.findall('types/type'):
+ parentStructs = type.get('structextends')
+ if (parentStructs != None):
+ for parent in parentStructs.split(','):
+ # self.gen.logMsg('diag', type.get('name'), 'extends', parent)
+ self.validextensionstructs[parent].append(type.get('name'))
+ # Sort the lists so they don't depend on the XML order
+ for parent in self.validextensionstructs:
+ self.validextensionstructs[parent].sort()
+
+ def dumpReg(self, maxlen = 120, filehandle = sys.stdout):
+ """Dump all the dictionaries constructed from the Registry object"""
+ write('***************************************', file=filehandle)
+ write(' ** Dumping Registry contents **', file=filehandle)
+ write('***************************************', file=filehandle)
+ write('// Types', file=filehandle)
+ for name in self.typedict:
+ tobj = self.typedict[name]
+ write(' Type', name, '->', etree.tostring(tobj.elem)[0:maxlen], file=filehandle)
+ write('// Groups', file=filehandle)
+ for name in self.groupdict:
+ gobj = self.groupdict[name]
+ write(' Group', name, '->', etree.tostring(gobj.elem)[0:maxlen], file=filehandle)
+ write('// Enums', file=filehandle)
+ for name in self.enumdict:
+ eobj = self.enumdict[name]
+ write(' Enum', name, '->', etree.tostring(eobj.elem)[0:maxlen], file=filehandle)
+ write('// Commands', file=filehandle)
+ for name in self.cmddict:
+ cobj = self.cmddict[name]
+ write(' Command', name, '->', etree.tostring(cobj.elem)[0:maxlen], file=filehandle)
+ write('// APIs', file=filehandle)
+ for key in self.apidict:
+ write(' API Version ', key, '->',
+ etree.tostring(self.apidict[key].elem)[0:maxlen], file=filehandle)
+ write('// Extensions', file=filehandle)
+ for key in self.extdict:
+ write(' Extension', key, '->',
+ etree.tostring(self.extdict[key].elem)[0:maxlen], file=filehandle)
+ # write('***************************************', file=filehandle)
+ # write(' ** Dumping XML ElementTree **', file=filehandle)
+ # write('***************************************', file=filehandle)
+ # write(etree.tostring(self.tree.getroot(),pretty_print=True), file=filehandle)
+ #
+ # typename - name of type
+ # required - boolean (to tag features as required or not)
+ def markTypeRequired(self, typename, required):
+ """Require (along with its dependencies) or remove (but not its dependencies) a type"""
+ self.gen.logMsg('diag', 'tagging type:', typename, '-> required =', required)
+ # Get TypeInfo object for <type> tag corresponding to typename
+ type = self.lookupElementInfo(typename, self.typedict)
+ if (type != None):
+ if (required):
+ # Tag type dependencies in 'alias' and 'required' attributes as
+ # required. This DOES NOT un-tag dependencies in a <remove>
+ # tag. See comments in markRequired() below for the reason.
+ for attrib in [ 'requires', 'alias' ]:
+ depname = type.elem.get(attrib)
+ if depname:
+ self.gen.logMsg('diag', 'Generating dependent type',
+ depname, 'for', attrib, 'type', typename)
+ self.markTypeRequired(depname, required)
+ # Tag types used in defining this type (e.g. in nested
+ # <type> tags)
+ # Look for <type> in entire <command> tree,
+ # not just immediate children
+ for subtype in type.elem.findall('.//type'):
+ self.gen.logMsg('diag', 'markRequired: type requires dependent <type>', subtype.text)
+ self.markTypeRequired(subtype.text, required)
+ # Tag enums used in defining this type, for example in
+ # <member><name>member</name>[<enum>MEMBER_SIZE</enum>]</member>
+ for subenum in type.elem.findall('.//enum'):
+ self.gen.logMsg('diag', 'markRequired: type requires dependent <enum>', subenum.text)
+ self.markEnumRequired(subenum.text, required)
+ type.required = required
+ else:
+ self.gen.logMsg('warn', 'type:', typename , 'IS NOT DEFINED')
+ #
+ # enumname - name of enum
+ # required - boolean (to tag features as required or not)
+ def markEnumRequired(self, enumname, required):
+ self.gen.logMsg('diag', 'tagging enum:', enumname, '-> required =', required)
+ enum = self.lookupElementInfo(enumname, self.enumdict)
+ if (enum != None):
+ enum.required = required
+ # Tag enum dependencies in 'alias' attribute as required
+ depname = enum.elem.get('alias')
+ if depname:
+ self.gen.logMsg('diag', 'Generating dependent enum',
+ depname, 'for alias', enumname, 'required =', enum.required)
+ self.markEnumRequired(depname, required)
+ else:
+ self.gen.logMsg('warn', 'enum:', enumname , 'IS NOT DEFINED')
+ #
+ # cmdname - name of command
+ # required - boolean (to tag features as required or not)
+ def markCmdRequired(self, cmdname, required):
+ self.gen.logMsg('diag', 'tagging command:', cmdname, '-> required =', required)
+ cmd = self.lookupElementInfo(cmdname, self.cmddict)
+ if (cmd != None):
+ cmd.required = required
+ # Tag command dependencies in 'alias' attribute as required
+ depname = cmd.elem.get('alias')
+ if depname:
+ self.gen.logMsg('diag', 'Generating dependent command',
+ depname, 'for alias', cmdname)
+ self.markCmdRequired(depname, required)
+ # Tag all parameter types of this command as required.
+ # This DOES NOT remove types of commands in a <remove>
+ # tag, because many other commands may use the same type.
+ # We could be more clever and reference count types,
+ # instead of using a boolean.
+ if (required):
+ # Look for <type> in entire <command> tree,
+ # not just immediate children
+ for type in cmd.elem.findall('.//type'):
+ self.gen.logMsg('diag', 'markRequired: command implicitly requires dependent type', type.text)
+ self.markTypeRequired(type.text, required)
+ else:
+ self.gen.logMsg('warn', 'command:', name, 'IS NOT DEFINED')
+ #
+ # features - Element for <require> or <remove> tag
+ # required - boolean (to tag features as required or not)
+ def markRequired(self, features, required):
+ """Require or remove features specified in the Element"""
+ self.gen.logMsg('diag', 'markRequired (features = <too long to print>, required =', required, ')')
+ # Loop over types, enums, and commands in the tag
+ # @@ It would be possible to respect 'api' and 'profile' attributes
+ # in individual features, but that's not done yet.
+ for typeElem in features.findall('type'):
+ self.markTypeRequired(typeElem.get('name'), required)
+ for enumElem in features.findall('enum'):
+ self.markEnumRequired(enumElem.get('name'), required)
+ for cmdElem in features.findall('command'):
+ self.markCmdRequired(cmdElem.get('name'), required)
+ #
+ # interface - Element for <version> or <extension>, containing
+ # <require> and <remove> tags
+ # api - string specifying API name being generated
+ # profile - string specifying API profile being generated
+ def requireAndRemoveFeatures(self, interface, api, profile):
+ """Process <recquire> and <remove> tags for a <version> or <extension>"""
+ # <require> marks things that are required by this version/profile
+ for feature in interface.findall('require'):
+ if (matchAPIProfile(api, profile, feature)):
+ self.markRequired(feature,True)
+ # <remove> marks things that are removed by this version/profile
+ for feature in interface.findall('remove'):
+ if (matchAPIProfile(api, profile, feature)):
+ self.markRequired(feature,False)
+
+ def assignAdditionalValidity(self, interface, api, profile):
+ #
+ # Loop over all usage inside all <require> tags.
+ for feature in interface.findall('require'):
+ if (matchAPIProfile(api, profile, feature)):
+ for v in feature.findall('usage'):
+ if v.get('command'):
+ self.cmddict[v.get('command')].additionalValidity.append(copy.deepcopy(v))
+ if v.get('struct'):
+ self.typedict[v.get('struct')].additionalValidity.append(copy.deepcopy(v))
+
+ #
+ # Loop over all usage inside all <remove> tags.
+ for feature in interface.findall('remove'):
+ if (matchAPIProfile(api, profile, feature)):
+ for v in feature.findall('usage'):
+ if v.get('command'):
+ self.cmddict[v.get('command')].removedValidity.append(copy.deepcopy(v))
+ if v.get('struct'):
+ self.typedict[v.get('struct')].removedValidity.append(copy.deepcopy(v))
+
+ #
+ # generateFeature - generate a single type / enum group / enum / command,
+ # and all its dependencies as needed.
+ # fname - name of feature (<type>/<enum>/<command>)
+ # ftype - type of feature, 'type' | 'enum' | 'command'
+ # dictionary - of *Info objects - self.{type|enum|cmd}dict
+ def generateFeature(self, fname, ftype, dictionary):
+ #@ # Break to debugger on matching name pattern
+ #@ if self.breakPat and re.match(self.breakPat, fname):
+ #@ pdb.set_trace()
+
+ self.gen.logMsg('diag', 'generateFeature: generating', ftype, fname)
+ f = self.lookupElementInfo(fname, dictionary)
+ if (f == None):
+ # No such feature. This is an error, but reported earlier
+ self.gen.logMsg('diag', 'No entry found for feature', fname,
+ 'returning!')
+ return
+ #
+ # If feature isn't required, or has already been declared, return
+ if (not f.required):
+ self.gen.logMsg('diag', 'Skipping', ftype, fname, '(not required)')
+ return
+ if (f.declared):
+ self.gen.logMsg('diag', 'Skipping', ftype, fname, '(already declared)')
+ return
+ # Always mark feature declared, as though actually emitted
+ f.declared = True
+
+ # Determine if this is an alias, and of what, if so
+ alias = f.elem.get('alias')
+ if alias:
+ self.gen.logMsg('diag', fname, 'is an alias of', alias)
+
+ #
+ # Pull in dependent declaration(s) of the feature.
+ # For types, there may be one type in the 'required' attribute of
+ # the element, one in the 'alias' attribute, and many in
+ # imbedded <type> and <enum> tags within the element.
+ # For commands, there may be many in <type> tags within the element.
+ # For enums, no dependencies are allowed (though perhaps if you
+ # have a uint64 enum, it should require that type).
+ genProc = None
+ if (ftype == 'type'):
+ genProc = self.gen.genType
+
+ # Generate type dependencies in 'alias' and 'required' attributes
+ if alias:
+ self.generateFeature(alias, 'type', self.typedict)
+ requires = f.elem.get('requires')
+ if requires:
+ self.generateFeature(requires, 'type', self.typedict)
+
+ # Generate types used in defining this type (e.g. in nested
+ # <type> tags)
+ # Look for <type> in entire <command> tree,
+ # not just immediate children
+ for subtype in f.elem.findall('.//type'):
+ self.gen.logMsg('diag', 'Generating required dependent <type>',
+ subtype.text)
+ self.generateFeature(subtype.text, 'type', self.typedict)
+
+ # Generate enums used in defining this type, for example in
+ # <member><name>member</name>[<enum>MEMBER_SIZE</enum>]</member>
+ for subtype in f.elem.findall('.//enum'):
+ self.gen.logMsg('diag', 'Generating required dependent <enum>',
+ subtype.text)
+ self.generateFeature(subtype.text, 'enum', self.enumdict)
+
+ # If the type is an enum group, look up the corresponding
+ # group in the group dictionary and generate that instead.
+ if (f.elem.get('category') == 'enum'):
+ self.gen.logMsg('diag', 'Type', fname, 'is an enum group, so generate that instead')
+ group = self.lookupElementInfo(fname, self.groupdict)
+ if alias != None:
+ # An alias of another group name.
+ # Pass to genGroup with 'alias' parameter = aliased name
+ self.gen.logMsg('diag', 'Generating alias', fname,
+ 'for enumerated type', alias)
+ # Now, pass the *aliased* GroupInfo to the genGroup, but
+ # with an additional parameter which is the alias name.
+ genProc = self.gen.genGroup
+ f = self.lookupElementInfo(alias, self.groupdict)
+ elif group == None:
+ self.gen.logMsg('warn', 'Skipping enum type', fname,
+ ': No matching enumerant group')
+ return
+ else:
+ genProc = self.gen.genGroup
+ f = group
+
+ #@ The enum group is not ready for generation. At this
+ #@ point, it contains all <enum> tags injected by
+ #@ <extension> tags without any verification of whether
+ #@ they're required or not. It may also contain
+ #@ duplicates injected by multiple consistent
+ #@ definitions of an <enum>.
+
+ #@ Pass over each enum, marking its enumdict[] entry as
+ #@ required or not. Mark aliases of enums as required,
+ #@ too.
+
+ enums = group.elem.findall('enum')
+
+ self.gen.logMsg('diag', 'generateFeature: checking enums for group', fname)
+
+ # Check for required enums, including aliases
+ # LATER - Check for, report, and remove duplicates?
+ enumAliases = []
+ for elem in enums:
+ name = elem.get('name')
+
+ required = False
+
+ extname = elem.get('extname')
+ version = elem.get('version')
+ if extname is not None:
+ # 'supported' attribute was injected when the <enum> element was
+ # moved into the <enums> group in Registry.parseTree()
+ if self.genOpts.defaultExtensions == elem.get('supported'):
+ required = True
+ elif re.match(self.genOpts.addExtensions, extname) is not None:
+ required = True
+ elif version is not None:
+ required = re.match(self.genOpts.emitversions, version) is not None
+ else:
+ required = True
+
+ self.gen.logMsg('diag', '* required =', required, 'for', name)
+ if required:
+ # Mark this element as required (in the element, not the EnumInfo)
+ elem.attrib['required'] = 'true'
+ # If it's an alias, track that for later use
+ enumAlias = elem.get('alias')
+ if enumAlias:
+ enumAliases.append(enumAlias)
+ for elem in enums:
+ name = elem.get('name')
+ if name in enumAliases:
+ elem.attrib['required'] = 'true'
+ self.gen.logMsg('diag', '* also need to require alias', name)
+ elif (ftype == 'command'):
+ # Generate command dependencies in 'alias' attribute
+ if alias:
+ self.generateFeature(alias, 'command', self.cmddict)
+
+ genProc = self.gen.genCmd
+ for type in f.elem.findall('.//type'):
+ depname = type.text
+ self.gen.logMsg('diag', 'Generating required parameter type',
+ depname)
+ self.generateFeature(depname, 'type', self.typedict)
+ elif (ftype == 'enum'):
+ # Generate enum dependencies in 'alias' attribute
+ if alias:
+ self.generateFeature(alias, 'enum', self.enumdict)
+ genProc = self.gen.genEnum
+
+ # Actually generate the type only if emitting declarations
+ if self.emitFeatures:
+ self.gen.logMsg('diag', 'Emitting', ftype, fname, 'declaration')
+ genProc(f, fname, alias)
+ else:
+ self.gen.logMsg('diag', 'Skipping', ftype, fname,
+ '(should not be emitted)')
+ #
+ # generateRequiredInterface - generate all interfaces required
+ # by an API version or extension
+ # interface - Element for <version> or <extension>
+ def generateRequiredInterface(self, interface):
+ """Generate required C interface for specified API version/extension"""
+
+ #
+ # Loop over all features inside all <require> tags.
+ for features in interface.findall('require'):
+ for t in features.findall('type'):
+ self.generateFeature(t.get('name'), 'type', self.typedict)
+ for e in features.findall('enum'):
+ self.generateFeature(e.get('name'), 'enum', self.enumdict)
+ for c in features.findall('command'):
+ self.generateFeature(c.get('name'), 'command', self.cmddict)
+
+ #
+ # apiGen(genOpts) - generate interface for specified versions
+ # genOpts - GeneratorOptions object with parameters used
+ # by the Generator object.
+ def apiGen(self, genOpts):
+ """Generate interfaces for the specified API type and range of versions"""
+ #
+ self.gen.logMsg('diag', '*******************************************')
+ self.gen.logMsg('diag', ' Registry.apiGen file:', genOpts.filename,
+ 'api:', genOpts.apiname,
+ 'profile:', genOpts.profile)
+ self.gen.logMsg('diag', '*******************************************')
+ #
+ self.genOpts = genOpts
+ # Reset required/declared flags for all features
+ self.apiReset()
+ #
+ # Compile regexps used to select versions & extensions
+ regVersions = re.compile(self.genOpts.versions)
+ regEmitVersions = re.compile(self.genOpts.emitversions)
+ regAddExtensions = re.compile(self.genOpts.addExtensions)
+ regRemoveExtensions = re.compile(self.genOpts.removeExtensions)
+ regEmitExtensions = re.compile(self.genOpts.emitExtensions)
+ #
+ # Get all matching API feature names & add to list of FeatureInfo
+ # Note we used to select on feature version attributes, not names.
+ features = []
+ apiMatch = False
+ for key in self.apidict:
+ fi = self.apidict[key]
+ api = fi.elem.get('api')
+ if (api == self.genOpts.apiname):
+ apiMatch = True
+ if (regVersions.match(fi.name)):
+ # Matches API & version #s being generated. Mark for
+ # emission and add to the features[] list .
+ # @@ Could use 'declared' instead of 'emit'?
+ fi.emit = (regEmitVersions.match(fi.name) != None)
+ features.append(fi)
+ if (not fi.emit):
+ self.gen.logMsg('diag', 'NOT tagging feature api =', api,
+ 'name =', fi.name, 'version =', fi.version,
+ 'for emission (does not match emitversions pattern)')
+ else:
+ self.gen.logMsg('diag', 'Including feature api =', api,
+ 'name =', fi.name, 'version =', fi.version,
+ 'for emission (matches emitversions pattern)')
+ else:
+ self.gen.logMsg('diag', 'NOT including feature api =', api,
+ 'name =', fi.name, 'version =', fi.version,
+ '(does not match requested versions)')
+ else:
+ self.gen.logMsg('diag', 'NOT including feature api =', api,
+ 'name =', fi.name,
+ '(does not match requested API)')
+ if (not apiMatch):
+ self.gen.logMsg('warn', 'No matching API versions found!')
+ #
+ # Get all matching extensions, in order by their extension number,
+ # and add to the list of features.
+ # Start with extensions tagged with 'api' pattern matching the API
+ # being generated. Add extensions matching the pattern specified in
+ # regExtensions, then remove extensions matching the pattern
+ # specified in regRemoveExtensions
+ for (extName,ei) in sorted(self.extdict.items(),key = lambda x : x[1].number):
+ extName = ei.name
+ include = False
+ #
+ # Include extension if defaultExtensions is not None and if the
+ # 'supported' attribute matches defaultExtensions. The regexp in
+ # 'supported' must exactly match defaultExtensions, so bracket
+ # it with ^(pat)$.
+ pat = '^(' + ei.elem.get('supported') + ')$'
+ if (self.genOpts.defaultExtensions and
+ re.match(pat, self.genOpts.defaultExtensions)):
+ self.gen.logMsg('diag', 'Including extension',
+ extName, "(defaultExtensions matches the 'supported' attribute)")
+ include = True
+ #
+ # Include additional extensions if the extension name matches
+ # the regexp specified in the generator options. This allows
+ # forcing extensions into an interface even if they're not
+ # tagged appropriately in the registry.
+ if (regAddExtensions.match(extName) != None):
+ self.gen.logMsg('diag', 'Including extension',
+ extName, '(matches explicitly requested extensions to add)')
+ include = True
+ # Remove extensions if the name matches the regexp specified
+ # in generator options. This allows forcing removal of
+ # extensions from an interface even if they're tagged that
+ # way in the registry.
+ if (regRemoveExtensions.match(extName) != None):
+ self.gen.logMsg('diag', 'Removing extension',
+ extName, '(matches explicitly requested extensions to remove)')
+ include = False
+ #
+ # If the extension is to be included, add it to the
+ # extension features list.
+ if (include):
+ ei.emit = (regEmitExtensions.match(extName) != None)
+ features.append(ei)
+ if (not ei.emit):
+ self.gen.logMsg('diag', 'NOT tagging extension',
+ extName,
+ 'for emission (does not match emitextensions pattern)')
+ # Hack - can be removed when validity generator goes away
+ # (Jon) I'm not sure what this does, or if it should respect
+ # the ei.emit flag above.
+ self.requiredextensions.append(extName)
+ else:
+ self.gen.logMsg('diag', 'NOT including extension',
+ extName, '(does not match api attribute or explicitly requested extensions)')
+ #
+ # Sort the extension features list, if a sort procedure is defined
+ if (self.genOpts.sortProcedure):
+ self.genOpts.sortProcedure(features)
+ #
+ # Pass 1: loop over requested API versions and extensions tagging
+ # types/commands/features as required (in an <require> block) or no
+ # longer required (in an <remove> block). It is possible to remove
+ # a feature in one version and restore it later by requiring it in
+ # a later version.
+ # If a profile other than 'None' is being generated, it must
+ # match the profile attribute (if any) of the <require> and
+ # <remove> tags.
+ self.gen.logMsg('diag', '*******PASS 1: TAG FEATURES **********')
+ for f in features:
+ self.gen.logMsg('diag', 'PASS 1: Tagging required and removed features for',
+ f.name)
+ self.requireAndRemoveFeatures(f.elem, self.genOpts.apiname, self.genOpts.profile)
+ self.assignAdditionalValidity(f.elem, self.genOpts.apiname, self.genOpts.profile)
+ #
+ # Pass 2: loop over specified API versions and extensions printing
+ # declarations for required things which haven't already been
+ # generated.
+ self.gen.logMsg('diag', '*******PASS 2: GENERATE INTERFACES FOR FEATURES **********')
+ self.gen.beginFile(self.genOpts)
+ for f in features:
+ self.gen.logMsg('diag', 'PASS 2: Generating interface for',
+ f.name)
+ emit = self.emitFeatures = f.emit
+ if (not emit):
+ self.gen.logMsg('diag', 'PASS 2: NOT declaring feature',
+ f.elem.get('name'), 'because it is not tagged for emission')
+ # Generate the interface (or just tag its elements as having been
+ # emitted, if they haven't been).
+ self.gen.beginFeature(f.elem, emit)
+ self.generateRequiredInterface(f.elem)
+ self.gen.endFeature()
+ self.gen.endFile()
+ #
+ # apiReset - use between apiGen() calls to reset internal state
+ #
+ def apiReset(self):
+ """Reset type/enum/command dictionaries before generating another API"""
+ for type in self.typedict:
+ self.typedict[type].resetState()
+ for enum in self.enumdict:
+ self.enumdict[enum].resetState()
+ for cmd in self.cmddict:
+ self.cmddict[cmd].resetState()
+ for cmd in self.apidict:
+ self.apidict[cmd].resetState()
+ #
+ # validateGroups - check that group= attributes match actual groups
+ #
+ def validateGroups(self):
+ """Validate group= attributes on <param> and <proto> tags"""
+ # Keep track of group names not in <group> tags
+ badGroup = {}
+ self.gen.logMsg('diag', 'VALIDATING GROUP ATTRIBUTES ***')
+ for cmd in self.reg.findall('commands/command'):
+ proto = cmd.find('proto')
+ funcname = cmd.find('proto/name').text
+ if ('group' in proto.attrib.keys()):
+ group = proto.get('group')
+ # self.gen.logMsg('diag', 'Command ', funcname, ' has return group ', group)
+ if (group not in self.groupdict.keys()):
+ # self.gen.logMsg('diag', 'Command ', funcname, ' has UNKNOWN return group ', group)
+ if (group not in badGroup.keys()):
+ badGroup[group] = 1
+ else:
+ badGroup[group] = badGroup[group] + 1
+ for param in cmd.findall('param'):
+ pname = param.find('name')
+ if (pname != None):
+ pname = pname.text
+ else:
+ pname = type.get('name')
+ if ('group' in param.attrib.keys()):
+ group = param.get('group')
+ if (group not in self.groupdict.keys()):
+ # self.gen.logMsg('diag', 'Command ', funcname, ' param ', pname, ' has UNKNOWN group ', group)
+ if (group not in badGroup.keys()):
+ badGroup[group] = 1
+ else:
+ badGroup[group] = badGroup[group] + 1
+ if (len(badGroup.keys()) > 0):
+ self.gen.logMsg('diag', 'SUMMARY OF UNRECOGNIZED GROUPS ***')
+ for key in sorted(badGroup.keys()):
+ self.gen.logMsg('diag', ' ', key, ' occurred ', badGroup[key], ' times')
--- /dev/null
+{\r
+ "version info": {\r
+ "schema version": 2,\r
+ "api version": "1.1.74",\r
+ "comment": "from git branch: master commit: c51545d33f4fd791dc4109d0d338e79b572f6286",\r
+ "date": "2018-04-23 18:29:18Z"\r
+ },\r
+ "validation": {\r
+ "vkGetInstanceProcAddr": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetInstanceProcAddr-instance-parameter",\r
+ "text": " If <code>instance</code> is not <code>NULL</code>, <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetInstanceProcAddr-pName-parameter",\r
+ "text": " <code>pName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceProcAddr": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceProcAddr-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceProcAddr-pName-parameter",\r
+ "text": " <code>pName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumerateInstanceVersion": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkEnumerateInstanceVersion-pApiVersion-parameter",\r
+ "text": " <code>pApiVersion</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateInstance": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateInstance-ppEnabledExtensionNames-01388",\r
+ "text": " All &amp;lt;&amp;lt;extended-functionality-extensions-dependencies, required extensions&amp;gt;&amp;gt; for each extension in the <a href=\"#VkInstanceCreateInfo\">VkInstanceCreateInfo</a>::<code>ppEnabledExtensionNames</code> list <strong class=\"purple\">must</strong> also be present in that list."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateInstance-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkInstanceCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateInstance-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateInstance-pInstance-parameter",\r
+ "text": " <code>pInstance</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkInstance</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkInstanceCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDebugReportCallbackCreateInfoEXT\">VkDebugReportCallbackCreateInfoEXT</a>, <a href=\"#VkDebugUtilsMessengerCreateInfoEXT\">VkDebugUtilsMessengerCreateInfoEXT</a>, or <a href=\"#VkValidationFlagsEXT\">VkValidationFlagsEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-pApplicationInfo-parameter",\r
+ "text": " If <code>pApplicationInfo</code> is not <code>NULL</code>, <code>pApplicationInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkApplicationInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-ppEnabledLayerNames-parameter",\r
+ "text": " If <code>enabledLayerCount</code> is not <code>0</code>, <code>ppEnabledLayerNames</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>enabledLayerCount</code> null-terminated UTF-8 strings"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInstanceCreateInfo-ppEnabledExtensionNames-parameter",\r
+ "text": " If <code>enabledExtensionCount</code> is not <code>0</code>, <code>ppEnabledExtensionNames</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>enabledExtensionCount</code> null-terminated UTF-8 strings"\r
+ }\r
+ ]\r
+ },\r
+ "VkValidationFlagsEXT": {\r
+ "(VK_EXT_validation_flags)": [\r
+ {\r
+ "vuid": "VUID-VkValidationFlagsEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationFlagsEXT-pDisabledValidationChecks-parameter",\r
+ "text": " <code>pDisabledValidationChecks</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>disabledValidationCheckCount</code> <a href=\"#VkValidationCheckEXT\">VkValidationCheckEXT</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationFlagsEXT-disabledValidationCheckCount-arraylength",\r
+ "text": " <code>disabledValidationCheckCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkApplicationInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkApplicationInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_APPLICATION_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkApplicationInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkApplicationInfo-pApplicationName-parameter",\r
+ "text": " If <code>pApplicationName</code> is not <code>NULL</code>, <code>pApplicationName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkApplicationInfo-pEngineName-parameter",\r
+ "text": " If <code>pEngineName</code> is not <code>NULL</code>, <code>pEngineName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyInstance": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyInstance-instance-00629",\r
+ "text": " All child objects created using <code>instance</code> <strong class=\"purple\">must</strong> have been destroyed prior to destroying <code>instance</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyInstance-instance-00630",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>instance</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyInstance-instance-00631",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>instance</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyInstance-instance-parameter",\r
+ "text": " If <code>instance</code> is not <code>NULL</code>, <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyInstance-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumeratePhysicalDevices": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkEnumeratePhysicalDevices-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumeratePhysicalDevices-pPhysicalDeviceCount-parameter",\r
+ "text": " <code>pPhysicalDeviceCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumeratePhysicalDevices-pPhysicalDevices-parameter",\r
+ "text": " If the value referenced by <code>pPhysicalDeviceCount</code> is not <code>0</code>, and <code>pPhysicalDevices</code> is not <code>NULL</code>, <code>pPhysicalDevices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPhysicalDeviceCount</code> <code>VkPhysicalDevice</code> handles"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceProperties-pProperties-parameter",\r
+ "text": " <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPhysicalDeviceProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceProperties2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceProperties2-pProperties-parameter",\r
+ "text": " <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPhysicalDeviceProperties2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceProperties2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceProperties2-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT\">VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT</a>, <a href=\"#VkPhysicalDeviceConservativeRasterizationPropertiesEXT\">VkPhysicalDeviceConservativeRasterizationPropertiesEXT</a>, <a href=\"#VkPhysicalDeviceDescriptorIndexingPropertiesEXT\">VkPhysicalDeviceDescriptorIndexingPropertiesEXT</a>, <a href=\"#VkPhysicalDeviceDiscardRectanglePropertiesEXT\">VkPhysicalDeviceDiscardRectanglePropertiesEXT</a>, <a href=\"#VkPhysicalDeviceExternalMemoryHostPropertiesEXT\">VkPhysicalDeviceExternalMemoryHostPropertiesEXT</a>, <a href=\"#VkPhysicalDeviceIDProperties\">VkPhysicalDeviceIDProperties</a>, <a href=\"#VkPhysicalDeviceMaintenance3Properties\">VkPhysicalDeviceMaintenance3Properties</a>, <a href=\"#VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX\">VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX</a>, <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>, <a href=\"#VkPhysicalDevicePointClippingProperties\">VkPhysicalDevicePointClippingProperties</a>, <a href=\"#VkPhysicalDeviceProtectedMemoryProperties\">VkPhysicalDeviceProtectedMemoryProperties</a>, <a href=\"#VkPhysicalDevicePushDescriptorPropertiesKHR\">VkPhysicalDevicePushDescriptorPropertiesKHR</a>, <a href=\"#VkPhysicalDeviceSampleLocationsPropertiesEXT\">VkPhysicalDeviceSampleLocationsPropertiesEXT</a>, <a href=\"#VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT\">VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT</a>, <a href=\"#VkPhysicalDeviceShaderCorePropertiesAMD\">VkPhysicalDeviceShaderCorePropertiesAMD</a>, <a href=\"#VkPhysicalDeviceSubgroupProperties\">VkPhysicalDeviceSubgroupProperties</a>, or <a href=\"#VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT\">VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceProperties2-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceIDProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)+(VK_VERSION_1_1,VK_KHR_external_memory_capabilities,VK_KHR_external_semaphore_capabilities,VK_KHR_external_fence_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceIDProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceQueueFamilyProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceQueueFamilyProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceQueueFamilyProperties-pQueueFamilyPropertyCount-parameter",\r
+ "text": " <code>pQueueFamilyPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceQueueFamilyProperties-pQueueFamilyProperties-parameter",\r
+ "text": " If the value referenced by <code>pQueueFamilyPropertyCount</code> is not <code>0</code>, and <code>pQueueFamilyProperties</code> is not <code>NULL</code>, <code>pQueueFamilyProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pQueueFamilyPropertyCount</code> <code>VkQueueFamilyProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceQueueFamilyProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceQueueFamilyProperties2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceQueueFamilyProperties2-pQueueFamilyPropertyCount-parameter",\r
+ "text": " <code>pQueueFamilyPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceQueueFamilyProperties2-pQueueFamilyProperties-parameter",\r
+ "text": " If the value referenced by <code>pQueueFamilyPropertyCount</code> is not <code>0</code>, and <code>pQueueFamilyProperties</code> is not <code>NULL</code>, <code>pQueueFamilyProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pQueueFamilyPropertyCount</code> <code>VkQueueFamilyProperties2</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkQueueFamilyProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkQueueFamilyProperties2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkQueueFamilyProperties2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumeratePhysicalDeviceGroups": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group_creation)": [\r
+ {\r
+ "vuid": "VUID-vkEnumeratePhysicalDeviceGroups-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumeratePhysicalDeviceGroups-pPhysicalDeviceGroupCount-parameter",\r
+ "text": " <code>pPhysicalDeviceGroupCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumeratePhysicalDeviceGroups-pPhysicalDeviceGroupProperties-parameter",\r
+ "text": " If the value referenced by <code>pPhysicalDeviceGroupCount</code> is not <code>0</code>, and <code>pPhysicalDeviceGroupProperties</code> is not <code>NULL</code>, <code>pPhysicalDeviceGroupProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPhysicalDeviceGroupCount</code> <code>VkPhysicalDeviceGroupProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDevice": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateDevice-ppEnabledExtensionNames-01387",\r
+ "text": " All &amp;lt;&amp;lt;extended-functionality-extensions-dependencies, required extensions&amp;gt;&amp;gt; for each extension in the <a href=\"#VkDeviceCreateInfo\">VkDeviceCreateInfo</a>::<code>ppEnabledExtensionNames</code> list <strong class=\"purple\">must</strong> also be present in that list."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDevice-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDevice-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDeviceCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDevice-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDevice-pDevice-parameter",\r
+ "text": " <code>pDevice</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDevice</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-queueFamilyIndex-00372",\r
+ "text": ""\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceGroupDeviceCreateInfo\">VkDeviceGroupDeviceCreateInfo</a>, <a href=\"#VkPhysicalDevice16BitStorageFeatures\">VkPhysicalDevice16BitStorageFeatures</a>, <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>, <a href=\"#VkPhysicalDeviceFeatures2\">VkPhysicalDeviceFeatures2</a>, <a href=\"#VkPhysicalDeviceMultiviewFeatures\">VkPhysicalDeviceMultiviewFeatures</a>, <a href=\"#VkPhysicalDeviceProtectedMemoryFeatures\">VkPhysicalDeviceProtectedMemoryFeatures</a>, <a href=\"#VkPhysicalDeviceSamplerYcbcrConversionFeatures\">VkPhysicalDeviceSamplerYcbcrConversionFeatures</a>, or <a href=\"#VkPhysicalDeviceVariablePointerFeatures\">VkPhysicalDeviceVariablePointerFeatures</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-pQueueCreateInfos-parameter",\r
+ "text": " <code>pQueueCreateInfos</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>queueCreateInfoCount</code> valid <code>VkDeviceQueueCreateInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-ppEnabledLayerNames-parameter",\r
+ "text": " If <code>enabledLayerCount</code> is not <code>0</code>, <code>ppEnabledLayerNames</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>enabledLayerCount</code> null-terminated UTF-8 strings"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-ppEnabledExtensionNames-parameter",\r
+ "text": " If <code>enabledExtensionCount</code> is not <code>0</code>, <code>ppEnabledExtensionNames</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>enabledExtensionCount</code> null-terminated UTF-8 strings"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-pEnabledFeatures-parameter",\r
+ "text": " If <code>pEnabledFeatures</code> is not <code>NULL</code>, <code>pEnabledFeatures</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceFeatures</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-queueCreateInfoCount-arraylength",\r
+ "text": " <code>queueCreateInfoCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-pNext-00373",\r
+ "text": " If the <code>pNext</code> chain includes a <a href=\"#VkPhysicalDeviceFeatures2\">VkPhysicalDeviceFeatures2</a> structure, then <code>pEnabledFeatures</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ],\r
+ "(VK_AMD_negative_viewport_height)+(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-ppEnabledExtensionNames-01840",\r
+ "text": " <code>ppEnabledExtensionNames</code> <strong class=\"purple\">must</strong> not contain <code>VK_AMD_negative_viewport_height</code>"\r
+ }\r
+ ],\r
+ "(VK_AMD_negative_viewport_height)+!(VK_VERSION_1_1)+(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceCreateInfo-ppEnabledExtensionNames-00374",\r
+ "text": " <code>ppEnabledExtensionNames</code> <strong class=\"purple\">must</strong> not contain both <code><a href=\"#VK_KHR_maintenance1\">VK_KHR_maintenance1</a></code> and <code><a href=\"#VK_AMD_negative_viewport_height\">VK_AMD_negative_viewport_height</a></code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupDeviceCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group_creation)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupDeviceCreateInfo-pPhysicalDevices-00375",\r
+ "text": " Each element of <code>pPhysicalDevices</code> <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupDeviceCreateInfo-pPhysicalDevices-00376",\r
+ "text": " All elements of <code>pPhysicalDevices</code> <strong class=\"purple\">must</strong> be in the same device group as enumerated by <a href=\"#vkEnumeratePhysicalDeviceGroups\">vkEnumeratePhysicalDeviceGroups</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupDeviceCreateInfo-physicalDeviceCount-00377",\r
+ "text": " If <code>physicalDeviceCount</code> is not <code>0</code>, the <code>physicalDevice</code> parameter of <a href=\"#vkCreateDevice\">vkCreateDevice</a> <strong class=\"purple\">must</strong> be an element of <code>pPhysicalDevices</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupDeviceCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupDeviceCreateInfo-pPhysicalDevices-parameter",\r
+ "text": " If <code>physicalDeviceCount</code> is not <code>0</code>, <code>pPhysicalDevices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>physicalDeviceCount</code> valid <code>VkPhysicalDevice</code> handles"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyDevice": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyDevice-device-00378",\r
+ "text": " All child objects created on <code>device</code> <strong class=\"purple\">must</strong> have been destroyed prior to destroying <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDevice-device-00379",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>device</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDevice-device-00380",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>device</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDevice-device-parameter",\r
+ "text": " If <code>device</code> is not <code>NULL</code>, <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDevice-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceQueueCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-queueFamilyIndex-00381",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-queueCount-00382",\r
+ "text": " <code>queueCount</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>queueCount</code> member of the <code>VkQueueFamilyProperties</code> structure, as returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> in the <code>pQueueFamilyProperties</code>[<code>queueFamilyIndex</code>]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-pQueuePriorities-00383",\r
+ "text": " Each element of <code>pQueuePriorities</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code> inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceQueueGlobalPriorityCreateInfoEXT\">VkDeviceQueueGlobalPriorityCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDeviceQueueCreateFlagBits\">VkDeviceQueueCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-pQueuePriorities-parameter",\r
+ "text": " <code>pQueuePriorities</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>queueCount</code> <code>float</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueCreateInfo-queueCount-arraylength",\r
+ "text": " <code>queueCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceQueueGlobalPriorityCreateInfoEXT": {\r
+ "(VK_EXT_global_priority)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueGlobalPriorityCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueGlobalPriorityCreateInfoEXT-globalPriority-parameter",\r
+ "text": " <code>globalPriority</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkQueueGlobalPriorityEXT\">VkQueueGlobalPriorityEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceQueue": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue-queueFamilyIndex-00384",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be one of the queue family indices specified when <code>device</code> was created, via the <code>VkDeviceQueueCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue-queueIndex-00385",\r
+ "text": " <code>queueIndex</code> <strong class=\"purple\">must</strong> be less than the number of queues created for the specified queue family index when <code>device</code> was created, via the <code>queueCount</code> member of the <code>VkDeviceQueueCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue-flags-01841",\r
+ "text": " <a href=\"#VkDeviceQueueCreateInfo\">VkDeviceQueueCreateInfo</a>::<code>flags</code> <strong class=\"purple\">must</strong> have been set to zero when <code>device</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue-pQueue-parameter",\r
+ "text": " <code>pQueue</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkQueue</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceQueue2": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue2-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue2-pQueueInfo-parameter",\r
+ "text": " <code>pQueueInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDeviceQueueInfo2</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceQueue2-pQueue-parameter",\r
+ "text": " <code>pQueue</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkQueue</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceQueueInfo2": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueInfo2-queueFamilyIndex-01842",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be one of the queue family indices specified when <code>device</code> was created, via the <code>VkDeviceQueueCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueInfo2-queueIndex-01843",\r
+ "text": " <code>queueIndex</code> <strong class=\"purple\">must</strong> be less than the number of queues created for the specified queue family index and <code>VkDeviceQueueCreateFlags</code> member <code>flags</code> equal to this <code>flags</code> value when <code>device</code> was created, via the <code>queueCount</code> member of the <code>VkDeviceQueueCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueInfo2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueInfo2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueInfo2-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDeviceQueueCreateFlagBits\">VkDeviceQueueCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceQueueInfo2-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateCommandPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateCommandPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateCommandPool-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkCommandPoolCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateCommandPool-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateCommandPool-pCommandPool-parameter",\r
+ "text": " <code>pCommandPool</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkCommandPool</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkCommandPoolCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkCommandPoolCreateInfo-queueFamilyIndex-00039",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be the index of a queue family available in the calling command’s <code>device</code> parameter"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandPoolCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandPoolCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandPoolCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkCommandPoolCreateFlagBits\">VkCommandPoolCreateFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkTrimCommandPool": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkTrimCommandPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkTrimCommandPool-commandPool-parameter",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkTrimCommandPool-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkTrimCommandPool-commandPool-parent",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkResetCommandPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkResetCommandPool-commandPool-00040",\r
+ "text": " All <code>VkCommandBuffer</code> objects allocated from <code>commandPool</code> <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandPool-commandPool-parameter",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandPool-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkCommandPoolResetFlagBits\">VkCommandPoolResetFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandPool-commandPool-parent",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyCommandPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-commandPool-00041",\r
+ "text": " All <code>VkCommandBuffer</code> objects allocated from <code>commandPool</code> <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-commandPool-00042",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>commandPool</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-commandPool-00043",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>commandPool</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-commandPool-parameter",\r
+ "text": " If <code>commandPool</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>commandPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyCommandPool-commandPool-parent",\r
+ "text": " If <code>commandPool</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkAllocateCommandBuffers": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkAllocateCommandBuffers-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateCommandBuffers-pAllocateInfo-parameter",\r
+ "text": " <code>pAllocateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkCommandBufferAllocateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateCommandBuffers-pCommandBuffers-parameter",\r
+ "text": " <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pAllocateInfo</code>::commandBufferCount <code>VkCommandBuffer</code> handles"\r
+ }\r
+ ]\r
+ },\r
+ "VkCommandBufferAllocateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkCommandBufferAllocateInfo-commandBufferCount-00044",\r
+ "text": " <code>commandBufferCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferAllocateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferAllocateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferAllocateInfo-commandPool-parameter",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferAllocateInfo-level-parameter",\r
+ "text": " <code>level</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkCommandBufferLevel\">VkCommandBufferLevel</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkResetCommandBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkResetCommandBuffer-commandBuffer-00045",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandBuffer-commandBuffer-00046",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been allocated from a pool that was created with the <code>VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetCommandBuffer-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkCommandBufferResetFlagBits\">VkCommandBufferResetFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkFreeCommandBuffers": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-pCommandBuffers-00047",\r
+ "text": " All elements of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-pCommandBuffers-00048",\r
+ "text": " <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>commandBufferCount</code> <code>VkCommandBuffer</code> handles, each element of which <strong class=\"purple\">must</strong> either be a valid handle or <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-commandPool-parameter",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-commandBufferCount-arraylength",\r
+ "text": " <code>commandBufferCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-commandPool-parent",\r
+ "text": " <code>commandPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeCommandBuffers-pCommandBuffers-parent",\r
+ "text": " Each element of <code>pCommandBuffers</code> that is a valid handle <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>commandPool</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkBeginCommandBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkBeginCommandBuffer-commandBuffer-00049",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording or pending state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBeginCommandBuffer-commandBuffer-00050",\r
+ "text": " If <code>commandBuffer</code> was allocated from a <a href=\"#VkCommandPool\">VkCommandPool</a> which did not have the <code>VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT</code> flag set, <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, initial state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBeginCommandBuffer-commandBuffer-00051",\r
+ "text": " If <code>commandBuffer</code> is a secondary command buffer, the <code>pInheritanceInfo</code> member of <code>pBeginInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBufferInheritanceInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBeginCommandBuffer-commandBuffer-00052",\r
+ "text": " If <code>commandBuffer</code> is a secondary command buffer and either the <code>occlusionQueryEnable</code> member of the <code>pInheritanceInfo</code> member of <code>pBeginInfo</code> is <code>VK_FALSE</code>, or the precise occlusion queries feature is not enabled, the <code>queryFlags</code> member of the <code>pInheritanceInfo</code> member <code>pBeginInfo</code> <strong class=\"purple\">must</strong> not contain <code>VK_QUERY_CONTROL_PRECISE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBeginCommandBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBeginCommandBuffer-pBeginInfo-parameter",\r
+ "text": " <code>pBeginInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkCommandBufferBeginInfo</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkCommandBufferBeginInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkCommandBufferBeginInfo-flags-00053",\r
+ "text": " If <code>flags</code> contains <code>VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT</code>, the <code>renderPass</code> member of <code>pInheritanceInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkRenderPass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferBeginInfo-flags-00054",\r
+ "text": " If <code>flags</code> contains <code>VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT</code>, the <code>subpass</code> member of <code>pInheritanceInfo</code> <strong class=\"purple\">must</strong> be a valid subpass index within the <code>renderPass</code> member of <code>pInheritanceInfo</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferBeginInfo-flags-00055",\r
+ "text": " If <code>flags</code> contains <code>VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT</code>, the <code>framebuffer</code> member of <code>pInheritanceInfo</code> <strong class=\"purple\">must</strong> be either <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, or a valid <code>VkFramebuffer</code> that is compatible with the <code>renderPass</code> member of <code>pInheritanceInfo</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferBeginInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferBeginInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceGroupCommandBufferBeginInfo\">VkDeviceGroupCommandBufferBeginInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferBeginInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkCommandBufferUsageFlagBits\">VkCommandBufferUsageFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkCommandBufferInheritanceInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkCommandBufferInheritanceInfo-occlusionQueryEnable-00056",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-inheritedQueries,inherited queries&amp;gt;&amp;gt; feature is not enabled, <code>occlusionQueryEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferInheritanceInfo-queryFlags-00057",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-inheritedQueries,inherited queries&amp;gt;&amp;gt; feature is enabled, <code>queryFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkQueryControlFlagBits\">VkQueryControlFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferInheritanceInfo-pipelineStatistics-00058",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-pipelineStatisticsQuery,pipeline statistics queries&amp;gt;&amp;gt; feature is not enabled, <code>pipelineStatistics</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferInheritanceInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferInheritanceInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCommandBufferInheritanceInfo-commonparent",\r
+ "text": " Both of <code>framebuffer</code>, and <code>renderPass</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkEndCommandBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkEndCommandBuffer-commandBuffer-00059",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEndCommandBuffer-commandBuffer-00060",\r
+ "text": " If <code>commandBuffer</code> is a primary command buffer, there <strong class=\"purple\">must</strong> not be an active render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEndCommandBuffer-commandBuffer-00061",\r
+ "text": " All queries made &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt; during the recording of <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been made inactive"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEndCommandBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ }\r
+ ],\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkEndCommandBuffer-commandBuffer-01815",\r
+ "text": " If <code>commandBuffer</code> is a secondary command buffer, there <strong class=\"purple\">must</strong> not be an outstanding <a href=\"#vkCmdBeginDebugUtilsLabelEXT\">vkCmdBeginDebugUtilsLabelEXT</a> command recorded to <code>commandBuffer</code> that has not previously been ended by a call to <a href=\"#vkCmdEndDebugUtilsLabelEXT\">vkCmdEndDebugUtilsLabelEXT</a>."\r
+ }\r
+ ],\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-vkEndCommandBuffer-commandBuffer-00062",\r
+ "text": " If <code>commandBuffer</code> is a secondary command buffer, there <strong class=\"purple\">must</strong> not be an outstanding <a href=\"#vkCmdDebugMarkerBeginEXT\">vkCmdDebugMarkerBeginEXT</a> command recorded to <code>commandBuffer</code> that has not previously been ended by a call to <a href=\"#vkCmdDebugMarkerEndEXT\">vkCmdDebugMarkerEndEXT</a>."\r
+ }\r
+ ]\r
+ },\r
+ "vkQueueSubmit": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-fence-00063",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be unsignaled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-fence-00064",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> not be associated with any other queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pCommandBuffers-00065",\r
+ "text": " Any calls to <a href=\"#vkCmdSetEvent\">vkCmdSetEvent</a>, <a href=\"#vkCmdResetEvent\">vkCmdResetEvent</a> or <a href=\"#vkCmdWaitEvents\">vkCmdWaitEvents</a> that have been recorded into any of the command buffer elements of the <code>pCommandBuffers</code> member of any element of <code>pSubmits</code>, <strong class=\"purple\">must</strong> not reference any <a href=\"#VkEvent\">VkEvent</a> that is referenced by any of those commands in a command buffer that has been submitted to another queue and is still in the <em>pending state</em>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pWaitDstStageMask-00066",\r
+ "text": " Any stage flag included in any element of the <code>pWaitDstStageMask</code> member of any element of <code>pSubmits</code> <strong class=\"purple\">must</strong> be a pipeline stage supported by one of the capabilities of <code>queue</code>, as specified in the &amp;lt;&amp;lt;synchronization-pipeline-stages-supported, table of supported pipeline stages&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pSignalSemaphores-00067",\r
+ "text": " Each element of the <code>pSignalSemaphores</code> member of any element of <code>pSubmits</code> <strong class=\"purple\">must</strong> be unsignaled when the semaphore signal operation it defines is executed on the device"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pWaitSemaphores-00068",\r
+ "text": " When a semaphore unsignal operation defined by any element of the <code>pWaitSemaphores</code> member of any element of <code>pSubmits</code> executes on <code>queue</code>, no other queue <strong class=\"purple\">must</strong> be waiting on the same semaphore."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pWaitSemaphores-00069",\r
+ "text": " All elements of the <code>pWaitSemaphores</code> member of all elements of <code>pSubmits</code> <strong class=\"purple\">must</strong> be semaphores that are signaled, or have &amp;lt;&amp;lt;synchronization-semaphores-signaling, semaphore signal operations&amp;gt;&amp;gt; previously submitted for execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pCommandBuffers-00070",\r
+ "text": " Each element of the <code>pCommandBuffers</code> member of each element of <code>pSubmits</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending or executable state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pCommandBuffers-00071",\r
+ "text": " If any element of the <code>pCommandBuffers</code> member of any element of <code>pSubmits</code> was not recorded with the <code>VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT</code>, it <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pCommandBuffers-00072",\r
+ "text": " Any &amp;lt;&amp;lt;commandbuffers-secondary, secondary command buffers recorded&amp;gt;&amp;gt; into any element of the <code>pCommandBuffers</code> member of any element of <code>pSubmits</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending or executable state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pCommandBuffers-00073",\r
+ "text": " If any &amp;lt;&amp;lt;commandbuffers-secondary, secondary command buffers recorded&amp;gt;&amp;gt; into any element of the <code>pCommandBuffers</code> member of any element of <code>pSubmits</code> was not recorded with the <code>VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT</code>, it <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pCommandBuffers-00074",\r
+ "text": " Each element of the <code>pCommandBuffers</code> member of each element of <code>pSubmits</code> <strong class=\"purple\">must</strong> have been allocated from a <code>VkCommandPool</code> that was created for the same queue family <code>queue</code> belongs to."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-pSubmits-parameter",\r
+ "text": " If <code>submitCount</code> is not <code>0</code>, <code>pSubmits</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>submitCount</code> valid <code>VkSubmitInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-fence-parameter",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueSubmit-commonparent",\r
+ "text": " Both of <code>fence</code>, and <code>queue</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSubmitInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pCommandBuffers-00075",\r
+ "text": " Each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> not have been allocated with <code>VK_COMMAND_BUFFER_LEVEL_SECONDARY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pWaitDstStageMask-00076",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, each element of <code>pWaitDstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pWaitDstStageMask-00077",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, each element of <code>pWaitDstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pWaitDstStageMask-00078",\r
+ "text": " Each element of <code>pWaitDstStageMask</code> <strong class=\"purple\">must</strong> not include <code>VK_PIPELINE_STAGE_HOST_BIT</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SUBMIT_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkD3D12FenceSubmitInfoKHR\">VkD3D12FenceSubmitInfoKHR</a>, <a href=\"#VkDeviceGroupSubmitInfo\">VkDeviceGroupSubmitInfo</a>, <a href=\"#VkProtectedSubmitInfo\">VkProtectedSubmitInfo</a>, <a href=\"#VkWin32KeyedMutexAcquireReleaseInfoKHR\">VkWin32KeyedMutexAcquireReleaseInfoKHR</a>, or <a href=\"#VkWin32KeyedMutexAcquireReleaseInfoNV\">VkWin32KeyedMutexAcquireReleaseInfoNV</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pWaitSemaphores-parameter",\r
+ "text": " If <code>waitSemaphoreCount</code> is not <code>0</code>, <code>pWaitSemaphores</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>waitSemaphoreCount</code> valid <code>VkSemaphore</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pWaitDstStageMask-parameter",\r
+ "text": " If <code>waitSemaphoreCount</code> is not <code>0</code>, <code>pWaitDstStageMask</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>waitSemaphoreCount</code> valid combinations of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pWaitDstStageMask-requiredbitmask",\r
+ "text": " Each element of <code>pWaitDstStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pCommandBuffers-parameter",\r
+ "text": " If <code>commandBufferCount</code> is not <code>0</code>, <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>commandBufferCount</code> valid <code>VkCommandBuffer</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-pSignalSemaphores-parameter",\r
+ "text": " If <code>signalSemaphoreCount</code> is not <code>0</code>, <code>pSignalSemaphores</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>signalSemaphoreCount</code> valid <code>VkSemaphore</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubmitInfo-commonparent",\r
+ "text": " Each of the elements of <code>pCommandBuffers</code>, the elements of <code>pSignalSemaphores</code>, and the elements of <code>pWaitSemaphores</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkD3D12FenceSubmitInfoKHR": {\r
+ "(VK_KHR_external_semaphore_win32)": [\r
+ {\r
+ "vuid": "VUID-VkD3D12FenceSubmitInfoKHR-waitSemaphoreValuesCount-00079",\r
+ "text": " <code>waitSemaphoreValuesCount</code> <strong class=\"purple\">must</strong> be the same value as <code>VkSubmitInfo</code>::<code>waitSemaphoreCount</code>, where <code>VkSubmitInfo</code> is in the <code>pNext</code> chain of this <code>VkD3D12FenceSubmitInfoKHR</code> structure."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkD3D12FenceSubmitInfoKHR-signalSemaphoreValuesCount-00080",\r
+ "text": " <code>signalSemaphoreValuesCount</code> <strong class=\"purple\">must</strong> be the same value as <code>VkSubmitInfo</code>::<code>signalSemaphoreCount</code>, where <code>VkSubmitInfo</code> is in the <code>pNext</code> chain of this <code>VkD3D12FenceSubmitInfoKHR</code> structure."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkD3D12FenceSubmitInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_D3D12_FENCE_SUBMIT_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkD3D12FenceSubmitInfoKHR-pWaitSemaphoreValues-parameter",\r
+ "text": " If <code>waitSemaphoreValuesCount</code> is not <code>0</code>, and <code>pWaitSemaphoreValues</code> is not <code>NULL</code>, <code>pWaitSemaphoreValues</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>waitSemaphoreValuesCount</code> <code>uint64_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkD3D12FenceSubmitInfoKHR-pSignalSemaphoreValues-parameter",\r
+ "text": " If <code>signalSemaphoreValuesCount</code> is not <code>0</code>, and <code>pSignalSemaphoreValues</code> is not <code>NULL</code>, <code>pSignalSemaphoreValues</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>signalSemaphoreValuesCount</code> <code>uint64_t</code> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkWin32KeyedMutexAcquireReleaseInfoKHR": {\r
+ "(VK_KHR_win32_keyed_mutex)": [\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-pAcquireSyncs-00081",\r
+ "text": " Each member of <code>pAcquireSyncs</code> and <code>pReleaseSyncs</code> <strong class=\"purple\">must</strong> be a device memory object imported by setting <a href=\"#VkImportMemoryWin32HandleInfoKHR\">VkImportMemoryWin32HandleInfoKHR</a>::<code>handleType</code> to <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT</code> or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-pAcquireSyncs-parameter",\r
+ "text": " If <code>acquireCount</code> is not <code>0</code>, <code>pAcquireSyncs</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>acquireCount</code> valid <code>VkDeviceMemory</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-pAcquireKeys-parameter",\r
+ "text": " If <code>acquireCount</code> is not <code>0</code>, <code>pAcquireKeys</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>acquireCount</code> <code>uint64_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-pAcquireTimeouts-parameter",\r
+ "text": " If <code>acquireCount</code> is not <code>0</code>, <code>pAcquireTimeouts</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>acquireCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-pReleaseSyncs-parameter",\r
+ "text": " If <code>releaseCount</code> is not <code>0</code>, <code>pReleaseSyncs</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>releaseCount</code> valid <code>VkDeviceMemory</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-pReleaseKeys-parameter",\r
+ "text": " If <code>releaseCount</code> is not <code>0</code>, <code>pReleaseKeys</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>releaseCount</code> <code>uint64_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoKHR-commonparent",\r
+ "text": " Both of the elements of <code>pAcquireSyncs</code>, and the elements of <code>pReleaseSyncs</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkWin32KeyedMutexAcquireReleaseInfoNV": {\r
+ "(VK_NV_win32_keyed_mutex)": [\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-pAcquireSyncs-parameter",\r
+ "text": " If <code>acquireCount</code> is not <code>0</code>, <code>pAcquireSyncs</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>acquireCount</code> valid <code>VkDeviceMemory</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-pAcquireKeys-parameter",\r
+ "text": " If <code>acquireCount</code> is not <code>0</code>, <code>pAcquireKeys</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>acquireCount</code> <code>uint64_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-pAcquireTimeoutMilliseconds-parameter",\r
+ "text": " If <code>acquireCount</code> is not <code>0</code>, <code>pAcquireTimeoutMilliseconds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>acquireCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-pReleaseSyncs-parameter",\r
+ "text": " If <code>releaseCount</code> is not <code>0</code>, <code>pReleaseSyncs</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>releaseCount</code> valid <code>VkDeviceMemory</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-pReleaseKeys-parameter",\r
+ "text": " If <code>releaseCount</code> is not <code>0</code>, <code>pReleaseKeys</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>releaseCount</code> <code>uint64_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32KeyedMutexAcquireReleaseInfoNV-commonparent",\r
+ "text": " Both of the elements of <code>pAcquireSyncs</code>, and the elements of <code>pReleaseSyncs</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkProtectedSubmitInfo": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkProtectedSubmitInfo-protectedSubmit-01816",\r
+ "text": " If the protected memory feature is not enabled, <code>protectedSubmit</code> <strong class=\"purple\">must</strong> not be <code>VK_TRUE</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkProtectedSubmitInfo-protectedSubmit-01817",\r
+ "text": " If <code>protectedSubmit</code> is <code>VK_TRUE</code>, then each element of the <code>pCommandBuffers</code> array <strong class=\"purple\">must</strong> be a protected command buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkProtectedSubmitInfo-protectedSubmit-01818",\r
+ "text": " If <code>protectedSubmit</code> is <code>VK_FALSE</code>, then each element of the <code>pCommandBuffers</code> array <strong class=\"purple\">must</strong> be an unprotected command buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkProtectedSubmitInfo-pNext-01819",\r
+ "text": " If the <code>VkSubmitInfo</code>::<code>pNext</code> chain does not include a <code>VkProtectedSubmitInfo</code> structure, then each element of the command buffer of the <code>pCommandBuffers</code> array <strong class=\"purple\">must</strong> be an unprotected command buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkProtectedSubmitInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupSubmitInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-waitSemaphoreCount-00082",\r
+ "text": " <code>waitSemaphoreCount</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkSubmitInfo\">VkSubmitInfo</a>::<code>waitSemaphoreCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-commandBufferCount-00083",\r
+ "text": " <code>commandBufferCount</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkSubmitInfo\">VkSubmitInfo</a>::<code>commandBufferCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-signalSemaphoreCount-00084",\r
+ "text": " <code>signalSemaphoreCount</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkSubmitInfo\">VkSubmitInfo</a>::<code>signalSemaphoreCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-pWaitSemaphoreDeviceIndices-00085",\r
+ "text": " All elements of <code>pWaitSemaphoreDeviceIndices</code> and <code>pSignalSemaphoreDeviceIndices</code> <strong class=\"purple\">must</strong> be valid device indices"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-pCommandBufferDeviceMasks-00086",\r
+ "text": " All elements of <code>pCommandBufferDeviceMasks</code> <strong class=\"purple\">must</strong> be valid device masks"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-pWaitSemaphoreDeviceIndices-parameter",\r
+ "text": " If <code>waitSemaphoreCount</code> is not <code>0</code>, <code>pWaitSemaphoreDeviceIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>waitSemaphoreCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-pCommandBufferDeviceMasks-parameter",\r
+ "text": " If <code>commandBufferCount</code> is not <code>0</code>, <code>pCommandBufferDeviceMasks</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>commandBufferCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSubmitInfo-pSignalSemaphoreDeviceIndices-parameter",\r
+ "text": " If <code>signalSemaphoreCount</code> is not <code>0</code>, <code>pSignalSemaphoreDeviceIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>signalSemaphoreCount</code> <code>uint32_t</code> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdExecuteCommands": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-00087",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been allocated with a <code>level</code> of <code>VK_COMMAND_BUFFER_LEVEL_PRIMARY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00088",\r
+ "text": " Each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been allocated with a <code>level</code> of <code>VK_COMMAND_BUFFER_LEVEL_SECONDARY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00089",\r
+ "text": " Each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending or executable state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00090",\r
+ "text": " If any element of <code>pCommandBuffers</code> was not recorded with the <code>VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT</code> flag, and it was recorded into any other primary command buffer, that primary command buffer <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00091",\r
+ "text": " If any element of <code>pCommandBuffers</code> was not recorded with the <code>VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT</code> flag, it <strong class=\"purple\">must</strong> not be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00092",\r
+ "text": " If any element of <code>pCommandBuffers</code> was not recorded with the <code>VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT</code> flag, it <strong class=\"purple\">must</strong> not have already been recorded to <code>commandBuffer</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00093",\r
+ "text": " If any element of <code>pCommandBuffers</code> was not recorded with the <code>VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT</code> flag, it <strong class=\"purple\">must</strong> not appear more than once in <code>pCommandBuffers</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00094",\r
+ "text": " Each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been allocated from a <code>VkCommandPool</code> that was created for the same queue family as the <code>VkCommandPool</code> from which <code>commandBuffer</code> was allocated"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-contents-00095",\r
+ "text": " If <code>vkCmdExecuteCommands</code> is being called within a render pass instance, that render pass instance <strong class=\"purple\">must</strong> have been begun with the <code>contents</code> parameter of <code>vkCmdBeginRenderPass</code> set to <code>VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00096",\r
+ "text": " If <code>vkCmdExecuteCommands</code> is being called within a render pass instance, each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been recorded with the <code>VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00097",\r
+ "text": " If <code>vkCmdExecuteCommands</code> is being called within a render pass instance, each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been recorded with <code>VkCommandBufferInheritanceInfo</code>::<code>subpass</code> set to the index of the subpass which the given command buffer will be executed in"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pInheritanceInfo-00098",\r
+ "text": " If <code>vkCmdExecuteCommands</code> is being called within a render pass instance, the render passes specified in the pname::pBeginInfo::<code>pInheritanceInfo</code>::<code>renderPass</code> members of the <a href=\"#vkBeginCommandBuffer\">vkBeginCommandBuffer</a> commands used to begin recording each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the current render pass."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00099",\r
+ "text": " If <code>vkCmdExecuteCommands</code> is being called within a render pass instance, and any element of <code>pCommandBuffers</code> was recorded with <code>VkCommandBufferInheritanceInfo</code>::<code>framebuffer</code> not equal to <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, that <code>VkFramebuffer</code> <strong class=\"purple\">must</strong> match the <code>VkFramebuffer</code> used in the current render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00100",\r
+ "text": " If <code>vkCmdExecuteCommands</code> is not being called within a render pass instance, each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> not have been recorded with the <code>VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-00101",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-inheritedQueries,inherited queries&amp;gt;&amp;gt; feature is not enabled, <code>commandBuffer</code> <strong class=\"purple\">must</strong> not have any queries &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-00102",\r
+ "text": " If <code>commandBuffer</code> has a <code>VK_QUERY_TYPE_OCCLUSION</code> query &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt;, then each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been recorded with <code>VkCommandBufferInheritanceInfo</code>::<code>occlusionQueryEnable</code> set to <code>VK_TRUE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-00103",\r
+ "text": " If <code>commandBuffer</code> has a <code>VK_QUERY_TYPE_OCCLUSION</code> query &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt;, then each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been recorded with <code>VkCommandBufferInheritanceInfo</code>::<code>queryFlags</code> having all bits set that are set for the query"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-00104",\r
+ "text": " If <code>commandBuffer</code> has a <code>VK_QUERY_TYPE_PIPELINE_STATISTICS</code> query &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt;, then each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been recorded with <code>VkCommandBufferInheritanceInfo</code>::<code>pipelineStatistics</code> having all bits set that are set in the <code>VkQueryPool</code> the query uses"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-00105",\r
+ "text": " Each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> not begin any query types that are &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt; in <code>commandBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-pCommandBuffers-parameter",\r
+ "text": " <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>commandBufferCount</code> valid <code>VkCommandBuffer</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-bufferlevel",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a primary <code>VkCommandBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBufferCount-arraylength",\r
+ "text": " <code>commandBufferCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and the elements of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-01820",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be a protected command buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdExecuteCommands-commandBuffer-01821",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then each element of <code>pCommandBuffers</code> <strong class=\"purple\">must</strong> be an unprotected command buffer."\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupCommandBufferBeginInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupCommandBufferBeginInfo-deviceMask-00106",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> be a valid device mask value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupCommandBufferBeginInfo-deviceMask-00107",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> not be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupCommandBufferBeginInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetDeviceMask": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-deviceMask-00108",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> be a valid device mask value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-deviceMask-00109",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> not be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-deviceMask-00110",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> not include any set bits that were not in the <a href=\"#VkDeviceGroupCommandBufferBeginInfo\">VkDeviceGroupCommandBufferBeginInfo</a>::<code>deviceMask</code> value when the command buffer began recording."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-deviceMask-00111",\r
+ "text": " If <code>vkCmdSetDeviceMask</code> is called inside a render pass instance, <code>deviceMask</code> <strong class=\"purple\">must</strong> not include any set bits that were not in the <a href=\"#VkDeviceGroupRenderPassBeginInfo\">VkDeviceGroupRenderPassBeginInfo</a>::<code>deviceMask</code> value when the render pass instance began recording."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDeviceMask-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, compute, or transfer operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateFence": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateFence-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateFence-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkFenceCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateFence-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateFence-pFence-parameter",\r
+ "text": " <code>pFence</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkFence</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkFenceCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkFenceCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_FENCE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkExportFenceCreateInfo\">VkExportFenceCreateInfo</a> or <a href=\"#VkExportFenceWin32HandleInfoKHR\">VkExportFenceWin32HandleInfoKHR</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkFenceCreateFlagBits\">VkFenceCreateFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportFenceCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_fence)": [\r
+ {\r
+ "vuid": "VUID-VkExportFenceCreateInfo-handleTypes-01446",\r
+ "text": " The bits in <code>handleTypes</code> must be supported and compatible, as reported by <a href=\"#VkExternalFenceProperties\">VkExternalFenceProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportFenceCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportFenceCreateInfo-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalFenceHandleTypeFlagBits\">VkExternalFenceHandleTypeFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportFenceWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_fence_win32)": [\r
+ {\r
+ "vuid": "VUID-VkExportFenceWin32HandleInfoKHR-handleTypes-01447",\r
+ "text": " If <a href=\"#VkExportFenceCreateInfo\">VkExportFenceCreateInfo</a>::<code>handleTypes</code> does not include <code>VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT</code>, VkExportFenceWin32HandleInfoKHR <strong class=\"purple\">must</strong> not be in the <code>pNext</code> chain of <a href=\"#VkFenceCreateInfo\">VkFenceCreateInfo</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportFenceWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_FENCE_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportFenceWin32HandleInfoKHR-pAttributes-parameter",\r
+ "text": " If <code>pAttributes</code> is not <code>NULL</code>, <code>pAttributes</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>SECURITY_ATTRIBUTES</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetFenceWin32HandleKHR": {\r
+ "(VK_KHR_external_fence_win32)": [\r
+ {\r
+ "vuid": "VUID-vkGetFenceWin32HandleKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetFenceWin32HandleKHR-pGetWin32HandleInfo-parameter",\r
+ "text": " <code>pGetWin32HandleInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkFenceGetWin32HandleInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetFenceWin32HandleKHR-pHandle-parameter",\r
+ "text": " <code>pHandle</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>HANDLE</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkFenceGetWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_fence_win32)": [\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-handleType-01448",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportFenceCreateInfo\">VkExportFenceCreateInfo</a>::<code>handleTypes</code> when the <code>fence</code>’s current payload was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-handleType-01449",\r
+ "text": " If <code>handleType</code> is defined as an NT handle, <a href=\"#vkGetFenceWin32HandleKHR\">vkGetFenceWin32HandleKHR</a> <strong class=\"purple\">must</strong> be called no more than once for each valid unique combination of <code>fence</code> and <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-fence-01450",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> not currently have its payload replaced by an imported payload as described below in &amp;lt;&amp;lt;synchronization-fences-importing,Importing Fence Payloads&amp;gt;&amp;gt; unless that imported payload’s handle type was included in <a href=\"#VkExternalFenceProperties\">VkExternalFenceProperties</a>::<code>exportFromImportedHandleTypes</code> for <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-handleType-01451",\r
+ "text": " If <code>handleType</code> refers to a handle type with copy payload transference semantics, <code>fence</code> <strong class=\"purple\">must</strong> be signaled, or have an associated &amp;lt;&amp;lt;synchronization-fences-signaling,fence signal operation&amp;gt;&amp;gt; pending execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-handleType-01452",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be defined as an NT handle or a global share handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_FENCE_GET_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-fence-parameter",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetWin32HandleInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalFenceHandleTypeFlagBits\">VkExternalFenceHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetFenceFdKHR": {\r
+ "(VK_KHR_external_fence_fd)": [\r
+ {\r
+ "vuid": "VUID-vkGetFenceFdKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetFenceFdKHR-pGetFdInfo-parameter",\r
+ "text": " <code>pGetFdInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkFenceGetFdInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetFenceFdKHR-pFd-parameter",\r
+ "text": " <code>pFd</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>int</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkFenceGetFdInfoKHR": {\r
+ "(VK_KHR_external_fence_fd)": [\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-handleType-01453",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportFenceCreateInfo\">VkExportFenceCreateInfo</a>::<code>handleTypes</code> when <code>fence</code>’s current payload was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-handleType-01454",\r
+ "text": " If <code>handleType</code> refers to a handle type with copy payload transference semantics, <code>fence</code> <strong class=\"purple\">must</strong> be signaled, or have an associated &amp;lt;&amp;lt;synchronization-fences-signaling,fence signal operation&amp;gt;&amp;gt; pending execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-fence-01455",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> not currently have its payload replaced by an imported payload as described below in &amp;lt;&amp;lt;synchronization-fences-importing,Importing Fence Payloads&amp;gt;&amp;gt; unless that imported payload’s handle type was included in <a href=\"#VkExternalFenceProperties\">VkExternalFenceProperties</a>::<code>exportFromImportedHandleTypes</code> for <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-handleType-01456",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be defined as a POSIX file descriptor handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-fence-parameter",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFenceGetFdInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalFenceHandleTypeFlagBits\">VkExternalFenceHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyFence": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-fence-01120",\r
+ "text": " All &amp;lt;&amp;lt;devsandqueues-submission, queue submission&amp;gt;&amp;gt; commands that refer to <code>fence</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-fence-01121",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>fence</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-fence-01122",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>fence</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-fence-parameter",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFence-fence-parent",\r
+ "text": " If <code>fence</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetFenceStatus": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetFenceStatus-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetFenceStatus-fence-parameter",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetFenceStatus-fence-parent",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkResetFences": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkResetFences-pFences-01123",\r
+ "text": " Each element of <code>pFences</code> <strong class=\"purple\">must</strong> not be currently associated with any queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetFences-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetFences-pFences-parameter",\r
+ "text": " <code>pFences</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>fenceCount</code> valid <code>VkFence</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetFences-fenceCount-arraylength",\r
+ "text": " <code>fenceCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetFences-pFences-parent",\r
+ "text": " Each element of <code>pFences</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkWaitForFences": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkWaitForFences-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkWaitForFences-pFences-parameter",\r
+ "text": " <code>pFences</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>fenceCount</code> valid <code>VkFence</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkWaitForFences-fenceCount-arraylength",\r
+ "text": " <code>fenceCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkWaitForFences-pFences-parent",\r
+ "text": " Each element of <code>pFences</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkRegisterDeviceEventEXT": {\r
+ "(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-vkRegisterDeviceEventEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDeviceEventEXT-pDeviceEventInfo-parameter",\r
+ "text": " <code>pDeviceEventInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDeviceEventInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDeviceEventEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDeviceEventEXT-pFence-parameter",\r
+ "text": " <code>pFence</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkFence</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceEventInfoEXT": {\r
+ "(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceEventInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceEventInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceEventInfoEXT-deviceEvent-parameter",\r
+ "text": " <code>deviceEvent</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDeviceEventTypeEXT\">VkDeviceEventTypeEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkRegisterDisplayEventEXT": {\r
+ "(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-vkRegisterDisplayEventEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDisplayEventEXT-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDisplayEventEXT-pDisplayEventInfo-parameter",\r
+ "text": " <code>pDisplayEventInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDisplayEventInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDisplayEventEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterDisplayEventEXT-pFence-parameter",\r
+ "text": " <code>pFence</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkFence</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDisplayEventInfoEXT": {\r
+ "(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-VkDisplayEventInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayEventInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayEventInfoEXT-displayEvent-parameter",\r
+ "text": " <code>displayEvent</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDisplayEventTypeEXT\">VkDisplayEventTypeEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkImportFenceWin32HandleKHR": {\r
+ "(VK_KHR_external_fence_win32)": [\r
+ {\r
+ "vuid": "VUID-vkImportFenceWin32HandleKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkImportFenceWin32HandleKHR-pImportFenceWin32HandleInfo-parameter",\r
+ "text": " <code>pImportFenceWin32HandleInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImportFenceWin32HandleInfoKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportFenceWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_fence_win32)": [\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handleType-01457",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a value included in the &amp;lt;&amp;lt;synchronization-fence-handletypes-win32, Handle Types Supported by VkImportFenceWin32HandleInfoKHR&amp;gt;&amp;gt; table."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handleType-01459",\r
+ "text": " If <code>handleType</code> is not <code>VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT</code>, <code>name</code> <strong class=\"purple\">must</strong> be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handleType-01460",\r
+ "text": " If <code>handleType</code> is not <code>0</code> and <code>handle</code> is <code>NULL</code>, <code>name</code> <strong class=\"purple\">must</strong> name a valid synchronization primitive of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handleType-01461",\r
+ "text": " If <code>handleType</code> is not <code>0</code> and <code>name</code> is <code>NULL</code>, <code>handle</code> <strong class=\"purple\">must</strong> be a valid handle of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handle-01462",\r
+ "text": " If <code>handle</code> is not <code>NULL</code>, <code>name</code> must be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handle-01539",\r
+ "text": " If <code>handle</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in <a href=\"#external-fence-handle-types-compatibility\">external fence handle types compatibility</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-name-01540",\r
+ "text": " If <code>name</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in <a href=\"#external-fence-handle-types-compatibility\">external fence handle types compatibility</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_FENCE_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-fence-parameter",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkFenceImportFlagBits\">VkFenceImportFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceWin32HandleInfoKHR-handleType-parameter",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalFenceHandleTypeFlagBits\">VkExternalFenceHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkImportFenceFdKHR": {\r
+ "(VK_KHR_external_fence_fd)": [\r
+ {\r
+ "vuid": "VUID-vkImportFenceFdKHR-fence-01463",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> not be associated with any queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkImportFenceFdKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkImportFenceFdKHR-pImportFenceFdInfo-parameter",\r
+ "text": " <code>pImportFenceFdInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImportFenceFdInfoKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportFenceFdInfoKHR": {\r
+ "(VK_KHR_external_fence_fd)": [\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-handleType-01464",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a value included in the &amp;lt;&amp;lt;synchronization-fence-handletypes-fd, Handle Types Supported by VkImportFenceFdInfoKHR&amp;gt;&amp;gt; table."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-fd-01541",\r
+ "text": " <code>fd</code> <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in &amp;lt;&amp;lt;external-fence-handle-types-compatibility,external fence handle types compatibility&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-fence-parameter",\r
+ "text": " <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkFenceImportFlagBits\">VkFenceImportFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportFenceFdInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalFenceHandleTypeFlagBits\">VkExternalFenceHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateSemaphore": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateSemaphore-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSemaphore-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSemaphoreCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSemaphore-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSemaphore-pSemaphore-parameter",\r
+ "text": " <code>pSemaphore</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSemaphore</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkSemaphoreCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSemaphoreCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkExportSemaphoreCreateInfo\">VkExportSemaphoreCreateInfo</a> or <a href=\"#VkExportSemaphoreWin32HandleInfoKHR\">VkExportSemaphoreWin32HandleInfoKHR</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportSemaphoreCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_semaphore)": [\r
+ {\r
+ "vuid": "VUID-VkExportSemaphoreCreateInfo-handleTypes-01124",\r
+ "text": " The bits in <code>handleTypes</code> <strong class=\"purple\">must</strong> be supported and compatible, as reported by <a href=\"#VkExternalSemaphoreProperties\">VkExternalSemaphoreProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportSemaphoreCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportSemaphoreCreateInfo-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalSemaphoreHandleTypeFlagBits\">VkExternalSemaphoreHandleTypeFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportSemaphoreWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_semaphore_win32)": [\r
+ {\r
+ "vuid": "VUID-VkExportSemaphoreWin32HandleInfoKHR-handleTypes-01125",\r
+ "text": " If <a href=\"#VkExportSemaphoreCreateInfo\">VkExportSemaphoreCreateInfo</a>::<code>handleTypes</code> does not include <code>VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT</code> or <code>VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT</code>, <code>VkExportSemaphoreWin32HandleInfoKHR</code> <strong class=\"purple\">must</strong> not be in the <code>pNext</code> chain of <a href=\"#VkSemaphoreCreateInfo\">VkSemaphoreCreateInfo</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportSemaphoreWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportSemaphoreWin32HandleInfoKHR-pAttributes-parameter",\r
+ "text": " If <code>pAttributes</code> is not <code>NULL</code>, <code>pAttributes</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>SECURITY_ATTRIBUTES</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetSemaphoreWin32HandleKHR": {\r
+ "(VK_KHR_external_semaphore_win32)": [\r
+ {\r
+ "vuid": "VUID-vkGetSemaphoreWin32HandleKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSemaphoreWin32HandleKHR-pGetWin32HandleInfo-parameter",\r
+ "text": " <code>pGetWin32HandleInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSemaphoreGetWin32HandleInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSemaphoreWin32HandleKHR-pHandle-parameter",\r
+ "text": " <code>pHandle</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>HANDLE</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkSemaphoreGetWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_semaphore_win32)": [\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-handleType-01126",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportSemaphoreCreateInfo\">VkExportSemaphoreCreateInfo</a>::<code>handleTypes</code> when the <code>semaphore</code>’s current payload was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-handleType-01127",\r
+ "text": " If <code>handleType</code> is defined as an NT handle, <a href=\"#vkGetSemaphoreWin32HandleKHR\">vkGetSemaphoreWin32HandleKHR</a> <strong class=\"purple\">must</strong> be called no more than once for each valid unique combination of <code>semaphore</code> and <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-semaphore-01128",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> not currently have its payload replaced by an imported payload as described below in &amp;lt;&amp;lt;synchronization-semaphores-importing,Importing Semaphore Payloads&amp;gt;&amp;gt; unless that imported payload’s handle type was included in <a href=\"#VkExternalSemaphoreProperties\">VkExternalSemaphoreProperties</a>::<code>exportFromImportedHandleTypes</code> for <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-handleType-01129",\r
+ "text": " If <code>handleType</code> refers to a handle type with copy payload transference semantics, as defined below in &amp;lt;&amp;lt;synchronization-semaphores-importing,Importing Semaphore Payloads&amp;gt;&amp;gt;, there <strong class=\"purple\">must</strong> be no queue waiting on <code>semaphore</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-handleType-01130",\r
+ "text": " If <code>handleType</code> refers to a handle type with copy payload transference semantics, <code>semaphore</code> <strong class=\"purple\">must</strong> be signaled, or have an associated &amp;lt;&amp;lt;synchronization-semaphores-signaling,semaphore signal operation&amp;gt;&amp;gt; pending execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-handleType-01131",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be defined as an NT handle or a global share handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SEMAPHORE_GET_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-semaphore-parameter",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetWin32HandleInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalSemaphoreHandleTypeFlagBits\">VkExternalSemaphoreHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetSemaphoreFdKHR": {\r
+ "(VK_KHR_external_semaphore_fd)": [\r
+ {\r
+ "vuid": "VUID-vkGetSemaphoreFdKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSemaphoreFdKHR-pGetFdInfo-parameter",\r
+ "text": " <code>pGetFdInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSemaphoreGetFdInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSemaphoreFdKHR-pFd-parameter",\r
+ "text": " <code>pFd</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>int</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkSemaphoreGetFdInfoKHR": {\r
+ "(VK_KHR_external_semaphore_fd)": [\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-handleType-01132",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportSemaphoreCreateInfo\">VkExportSemaphoreCreateInfo</a>::<code>handleTypes</code> when <code>semaphore</code>’s current payload was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-semaphore-01133",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> not currently have its payload replaced by an imported payload as described below in &amp;lt;&amp;lt;synchronization-semaphores-importing,Importing Semaphore Payloads&amp;gt;&amp;gt; unless that imported payload’s handle type was included in <a href=\"#VkExternalSemaphoreProperties\">VkExternalSemaphoreProperties</a>::<code>exportFromImportedHandleTypes</code> for <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-handleType-01134",\r
+ "text": " If <code>handleType</code> refers to a handle type with copy payload transference semantics, as defined below in &amp;lt;&amp;lt;synchronization-semaphores-importing,Importing Semaphore Payloads&amp;gt;&amp;gt;, there <strong class=\"purple\">must</strong> be no queue waiting on <code>semaphore</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-handleType-01135",\r
+ "text": " If <code>handleType</code> refers to a handle type with copy payload transference semantics, <code>semaphore</code> <strong class=\"purple\">must</strong> be signaled, or have an associated &amp;lt;&amp;lt;synchronization-semaphores-signaling,semaphore signal operation&amp;gt;&amp;gt; pending execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-handleType-01136",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be defined as a POSIX file descriptor handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-semaphore-parameter",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSemaphoreGetFdInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalSemaphoreHandleTypeFlagBits\">VkExternalSemaphoreHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroySemaphore": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-semaphore-01137",\r
+ "text": " All submitted batches that refer to <code>semaphore</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-semaphore-01138",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>semaphore</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-semaphore-01139",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>semaphore</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-semaphore-parameter",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySemaphore-semaphore-parent",\r
+ "text": " If <code>semaphore</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkImportSemaphoreWin32HandleKHR": {\r
+ "(VK_KHR_external_semaphore_win32)": [\r
+ {\r
+ "vuid": "VUID-vkImportSemaphoreWin32HandleKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkImportSemaphoreWin32HandleKHR-pImportSemaphoreWin32HandleInfo-parameter",\r
+ "text": " <code>pImportSemaphoreWin32HandleInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImportSemaphoreWin32HandleInfoKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportSemaphoreWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_semaphore_win32)": [\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handleType-01140",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a value included in the &amp;lt;&amp;lt;synchronization-semaphore-handletypes-win32,Handle Types Supported by VkImportSemaphoreWin32HandleInfoKHR&amp;gt;&amp;gt; table."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handleType-01466",\r
+ "text": " If <code>handleType</code> is not <code>VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT</code> or <code>VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT</code>, <code>name</code> <strong class=\"purple\">must</strong> be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handleType-01467",\r
+ "text": " If <code>handleType</code> is not <code>0</code> and <code>handle</code> is <code>NULL</code>, <code>name</code> <strong class=\"purple\">must</strong> name a valid synchronization primitive of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handleType-01468",\r
+ "text": " If <code>handleType</code> is not <code>0</code> and <code>name</code> is <code>NULL</code>, <code>handle</code> <strong class=\"purple\">must</strong> be a valid handle of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handle-01469",\r
+ "text": " If <code>handle</code> is not <code>NULL</code>, <code>name</code> must be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handle-01542",\r
+ "text": " If <code>handle</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in <a href=\"#external-semaphore-handle-types-compatibility\">external semaphore handle types compatibility</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-name-01543",\r
+ "text": " If <code>name</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in <a href=\"#external-semaphore-handle-types-compatibility\">external semaphore handle types compatibility</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-semaphore-parameter",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSemaphoreImportFlagBits\">VkSemaphoreImportFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreWin32HandleInfoKHR-handleType-parameter",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalSemaphoreHandleTypeFlagBits\">VkExternalSemaphoreHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkImportSemaphoreFdKHR": {\r
+ "(VK_KHR_external_semaphore_fd)": [\r
+ {\r
+ "vuid": "VUID-vkImportSemaphoreFdKHR-semaphore-01142",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> not be associated with any queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkImportSemaphoreFdKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkImportSemaphoreFdKHR-pImportSemaphoreFdInfo-parameter",\r
+ "text": " <code>pImportSemaphoreFdInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImportSemaphoreFdInfoKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportSemaphoreFdInfoKHR": {\r
+ "(VK_KHR_external_semaphore_fd)": [\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-handleType-01143",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a value included in the &amp;lt;&amp;lt;synchronization-semaphore-handletypes-fd,Handle Types Supported by VkImportSemaphoreFdInfoKHR&amp;gt;&amp;gt; table."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-fd-01544",\r
+ "text": " <code>fd</code> <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in &amp;lt;&amp;lt;external-semaphore-handle-types-compatibility,external semaphore handle types compatibility&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-semaphore-parameter",\r
+ "text": " <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSemaphoreImportFlagBits\">VkSemaphoreImportFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportSemaphoreFdInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalSemaphoreHandleTypeFlagBits\">VkExternalSemaphoreHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateEvent": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateEvent-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateEvent-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkEventCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateEvent-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateEvent-pEvent-parameter",\r
+ "text": " <code>pEvent</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkEvent</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkEventCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkEventCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EVENT_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkEventCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkEventCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyEvent": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-event-01145",\r
+ "text": " All submitted commands that refer to <code>event</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-event-01146",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>event</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-event-01147",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>event</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-event-parameter",\r
+ "text": " If <code>event</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>event</code> <strong class=\"purple\">must</strong> be a valid <code>VkEvent</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyEvent-event-parent",\r
+ "text": " If <code>event</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetEventStatus": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetEventStatus-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetEventStatus-event-parameter",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> be a valid <code>VkEvent</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetEventStatus-event-parent",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkSetEvent": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkSetEvent-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetEvent-event-parameter",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> be a valid <code>VkEvent</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetEvent-event-parent",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkResetEvent": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkResetEvent-event-01148",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> not be waited on by a <code>vkCmdWaitEvents</code> command that is currently executing"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetEvent-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetEvent-event-parameter",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> be a valid <code>VkEvent</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetEvent-event-parent",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetEvent": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-stageMask-01149",\r
+ "text": " <code>stageMask</code> <strong class=\"purple\">must</strong> not include <code>VK_PIPELINE_STAGE_HOST_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-stageMask-01150",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>stageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-stageMask-01151",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>stageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-event-parameter",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> be a valid <code>VkEvent</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-stageMask-parameter",\r
+ "text": " <code>stageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-stageMask-requiredbitmask",\r
+ "text": " <code>stageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>event</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetEvent-commandBuffer-01152",\r
+ "text": " <code>commandBuffer</code>’s current device mask <strong class=\"purple\">must</strong> include exactly one physical device."\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdResetEvent": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-stageMask-01153",\r
+ "text": " <code>stageMask</code> <strong class=\"purple\">must</strong> not include <code>VK_PIPELINE_STAGE_HOST_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-stageMask-01154",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>stageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-stageMask-01155",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>stageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-event-01156",\r
+ "text": " When this command executes, <code>event</code> <strong class=\"purple\">must</strong> not be waited on by a <code>vkCmdWaitEvents</code> command that is currently executing"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-event-parameter",\r
+ "text": " <code>event</code> <strong class=\"purple\">must</strong> be a valid <code>VkEvent</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-stageMask-parameter",\r
+ "text": " <code>stageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-stageMask-requiredbitmask",\r
+ "text": " <code>stageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>event</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkCmdResetEvent-commandBuffer-01157",\r
+ "text": " <code>commandBuffer</code>’s current device mask <strong class=\"purple\">must</strong> include exactly one physical device."\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdWaitEvents": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-srcStageMask-01158",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> be the bitwise OR of the <code>stageMask</code> parameter used in previous calls to <code>vkCmdSetEvent</code> with any of the members of <code>pEvents</code> and <code>VK_PIPELINE_STAGE_HOST_BIT</code> if any of the members of <code>pEvents</code> was set using <code>vkSetEvent</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-srcStageMask-01159",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-dstStageMask-01160",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-srcStageMask-01161",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-dstStageMask-01162",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pEvents-01163",\r
+ "text": " If <code>pEvents</code> includes one or more events that will be signaled by <code>vkSetEvent</code> after <code>commandBuffer</code> has been submitted to a queue, then <code>vkCmdWaitEvents</code> <strong class=\"purple\">must</strong> not be called inside a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-srcStageMask-01164",\r
+ "text": " Any pipeline stage included in <code>srcStageMask</code> or <code>dstStageMask</code> <strong class=\"purple\">must</strong> be supported by the capabilities of the queue family specified by the <code>queueFamilyIndex</code> member of the <a href=\"#VkCommandPoolCreateInfo\">VkCommandPoolCreateInfo</a> structure that was used to create the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from, as specified in the &amp;lt;&amp;lt;synchronization-pipeline-stages-supported, table of supported pipeline stages&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pMemoryBarriers-01165",\r
+ "text": " Each element of <code>pMemoryBarriers</code>, <code>pBufferMemoryBarriers</code> or <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> not have any access flag included in its <code>srcAccessMask</code> member if that bit is not supported by any of the pipeline stages in <code>srcStageMask</code>, as specified in the &amp;lt;&amp;lt;synchronization-access-types-supported, table of supported access types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pMemoryBarriers-01166",\r
+ "text": " Each element of <code>pMemoryBarriers</code>, <code>pBufferMemoryBarriers</code> or <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> not have any access flag included in its <code>dstAccessMask</code> member if that bit is not supported by any of the pipeline stages in <code>dstStageMask</code>, as specified in the &amp;lt;&amp;lt;synchronization-access-types-supported, table of supported access types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pEvents-parameter",\r
+ "text": " <code>pEvents</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>eventCount</code> valid <code>VkEvent</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-srcStageMask-parameter",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-srcStageMask-requiredbitmask",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-dstStageMask-parameter",\r
+ "text": " <code>dstStageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-dstStageMask-requiredbitmask",\r
+ "text": " <code>dstStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pMemoryBarriers-parameter",\r
+ "text": " If <code>memoryBarrierCount</code> is not <code>0</code>, <code>pMemoryBarriers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>memoryBarrierCount</code> valid <code>VkMemoryBarrier</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pBufferMemoryBarriers-parameter",\r
+ "text": " If <code>bufferMemoryBarrierCount</code> is not <code>0</code>, <code>pBufferMemoryBarriers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bufferMemoryBarrierCount</code> valid <code>VkBufferMemoryBarrier</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-pImageMemoryBarriers-parameter",\r
+ "text": " If <code>imageMemoryBarrierCount</code> is not <code>0</code>, <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>imageMemoryBarrierCount</code> valid <code>VkImageMemoryBarrier</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-eventCount-arraylength",\r
+ "text": " <code>eventCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and the elements of <code>pEvents</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkCmdWaitEvents-commandBuffer-01167",\r
+ "text": " <code>commandBuffer</code>’s current device mask <strong class=\"purple\">must</strong> include exactly one physical device."\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdPipelineBarrier": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcStageMask-01168",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dstStageMask-01169",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcStageMask-01170",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dstStageMask-01171",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-pDependencies-01172",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the render pass <strong class=\"purple\">must</strong> have been created with a <code>VkSubpassDependency</code> instance in <code>pDependencies</code> that expresses a dependency from the current subpass to itself."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcStageMask-01173",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, <code>srcStageMask</code> <strong class=\"purple\">must</strong> contain a subset of the bit values in the <code>srcStageMask</code> member of that instance of <code>VkSubpassDependency</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dstStageMask-01174",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, <code>dstStageMask</code> <strong class=\"purple\">must</strong> contain a subset of the bit values in the <code>dstStageMask</code> member of that instance of <code>VkSubpassDependency</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcAccessMask-01175",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the <code>srcAccessMask</code> of any element of <code>pMemoryBarriers</code> or <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> contain a subset of the bit values the <code>srcAccessMask</code> member of that instance of <code>VkSubpassDependency</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dstAccessMask-01176",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the <code>dstAccessMask</code> of any element of <code>pMemoryBarriers</code> or <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> contain a subset of the bit values the <code>dstAccessMask</code> member of that instance of <code>VkSubpassDependency</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dependencyFlags-01177",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, <code>dependencyFlags</code> <strong class=\"purple\">must</strong> be equal to the <code>dependencyFlags</code> member of that instance of <code>VkSubpassDependency</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-bufferMemoryBarrierCount-01178",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, <code>bufferMemoryBarrierCount</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-image-01179",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the <code>image</code> member of any element of <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> be equal to one of the elements of <code>pAttachments</code> that the current <code>framebuffer</code> was created with, that is also referred to by one of the elements of the <code>pColorAttachments</code>, <code>pResolveAttachments</code> or <code>pDepthStencilAttachment</code> members of the <code>VkSubpassDescription</code> instance that the current subpass was created with"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-oldLayout-01180",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the <code>oldLayout</code> and <code>newLayout</code> members of any element of <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> be equal to the <code>layout</code> member of an element of the <code>pColorAttachments</code>, <code>pResolveAttachments</code> or <code>pDepthStencilAttachment</code> members of the <code>VkSubpassDescription</code> instance that the current subpass was created with, that refers to the same <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-oldLayout-01181",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the <code>oldLayout</code> and <code>newLayout</code> members of an element of <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> be equal"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcQueueFamilyIndex-01182",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called within a render pass instance, the <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> members of any element of <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> be <code>VK_QUEUE_FAMILY_IGNORED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcStageMask-01183",\r
+ "text": " Any pipeline stage included in <code>srcStageMask</code> or <code>dstStageMask</code> <strong class=\"purple\">must</strong> be supported by the capabilities of the queue family specified by the <code>queueFamilyIndex</code> member of the <a href=\"#VkCommandPoolCreateInfo\">VkCommandPoolCreateInfo</a> structure that was used to create the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from, as specified in the &amp;lt;&amp;lt;synchronization-pipeline-stages-supported, table of supported pipeline stages&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-pMemoryBarriers-01184",\r
+ "text": " Each element of <code>pMemoryBarriers</code>, <code>pBufferMemoryBarriers</code> and <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> not have any access flag included in its <code>srcAccessMask</code> member if that bit is not supported by any of the pipeline stages in <code>srcStageMask</code>, as specified in the &amp;lt;&amp;lt;synchronization-access-types-supported, table of supported access types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-pMemoryBarriers-01185",\r
+ "text": " Each element of <code>pMemoryBarriers</code>, <code>pBufferMemoryBarriers</code> and <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> not have any access flag included in its <code>dstAccessMask</code> member if that bit is not supported by any of the pipeline stages in <code>dstStageMask</code>, as specified in the &amp;lt;&amp;lt;synchronization-access-types-supported, table of supported access types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcStageMask-parameter",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-srcStageMask-requiredbitmask",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dstStageMask-parameter",\r
+ "text": " <code>dstStageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dstStageMask-requiredbitmask",\r
+ "text": " <code>dstStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dependencyFlags-parameter",\r
+ "text": " <code>dependencyFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDependencyFlagBits\">VkDependencyFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-pMemoryBarriers-parameter",\r
+ "text": " If <code>memoryBarrierCount</code> is not <code>0</code>, <code>pMemoryBarriers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>memoryBarrierCount</code> valid <code>VkMemoryBarrier</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-pBufferMemoryBarriers-parameter",\r
+ "text": " If <code>bufferMemoryBarrierCount</code> is not <code>0</code>, <code>pBufferMemoryBarriers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bufferMemoryBarrierCount</code> valid <code>VkBufferMemoryBarrier</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-pImageMemoryBarriers-parameter",\r
+ "text": " If <code>imageMemoryBarrierCount</code> is not <code>0</code>, <code>pImageMemoryBarriers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>imageMemoryBarrierCount</code> valid <code>VkImageMemoryBarrier</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdPipelineBarrier-dependencyFlags-01186",\r
+ "text": " If <code>vkCmdPipelineBarrier</code> is called outside of a render pass instance, <code>dependencyFlags</code> <strong class=\"purple\">must</strong> not include <code>VK_DEPENDENCY_VIEW_LOCAL_BIT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryBarrier": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkMemoryBarrier-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_BARRIER</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryBarrier-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryBarrier-srcAccessMask-parameter",\r
+ "text": " <code>srcAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryBarrier-dstAccessMask-parameter",\r
+ "text": " <code>dstAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkBufferMemoryBarrier": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-offset-01187",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-size-01188",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-size-01189",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to than the size of <code>buffer</code> minus <code>offset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01196",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code>, and <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> are not <code>VK_QUEUE_FAMILY_IGNORED</code>, at least one of them <strong class=\"purple\">must</strong> be the same as the family of the queue that will execute this barrier"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01931",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-srcAccessMask-parameter",\r
+ "text": " <code>srcAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-dstAccessMask-parameter",\r
+ "text": " <code>dstAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01190",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_CONCURRENT</code>, <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> both be <code>VK_QUEUE_FAMILY_IGNORED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01192",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code>, <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> either both be <code>VK_QUEUE_FAMILY_IGNORED</code>, or both be a valid queue family (see &amp;lt;&amp;lt;devsandqueues-queueprops&amp;gt;&amp;gt;)"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01191",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_CONCURRENT</code>, at least one of <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> be <code>VK_QUEUE_FAMILY_IGNORED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01763",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_CONCURRENT</code>, and one of <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> is <code>VK_QUEUE_FAMILY_IGNORED</code>, the other <strong class=\"purple\">must</strong> be <code>VK_QUEUE_FAMILY_IGNORED</code> or a special queue family reserved for external memory ownership transfers, as described in &amp;lt;&amp;lt;synchronization-queue-transfers&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01193",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code> and <code>srcQueueFamilyIndex</code> is <code>VK_QUEUE_FAMILY_IGNORED</code>, <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> also be <code>VK_QUEUE_FAMILY_IGNORED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01764",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code> and <code>srcQueueFamilyIndex</code> is not <code>VK_QUEUE_FAMILY_IGNORED</code>, it <strong class=\"purple\">must</strong> be a valid queue family or a special queue family reserved for external memory transfers, as described in &amp;lt;&amp;lt;synchronization-queue-transfers&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryBarrier-buffer-01765",\r
+ "text": " If <code>buffer</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code> and <code>dstQueueFamilyIndex</code> is not <code>VK_QUEUE_FAMILY_IGNORED</code>, it <strong class=\"purple\">must</strong> be a valid queue family or a special queue family reserved for external memory transfers, as described in &amp;lt;&amp;lt;synchronization-queue-transfers&amp;gt;&amp;gt;."\r
+ }\r
+ ]\r
+ },\r
+ "VkImageMemoryBarrier": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01197",\r
+ "text": " <code>oldLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_UNDEFINED</code> or the current layout of the image subresources affected by the barrier"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-newLayout-01198",\r
+ "text": " <code>newLayout</code> <strong class=\"purple\">must</strong> not be <code>VK_IMAGE_LAYOUT_UNDEFINED</code> or <code>VK_IMAGE_LAYOUT_PREINITIALIZED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01205",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code>, and <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> are not <code>VK_QUEUE_FAMILY_IGNORED</code>, at least one of them <strong class=\"purple\">must</strong> be the same as the family of the queue that will execute this barrier"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-subresourceRange-01486",\r
+ "text": " <code>subresourceRange.baseMipLevel</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-subresourceRange-01724",\r
+ "text": " If <code>subresourceRange.levelCount</code> is not <code>VK_REMAINING_MIP_LEVELS</code>, <span class=\"eq\"><code>subresourceRange.baseMipLevel</code> + <code>subresourceRange.levelCount</code></span> <strong class=\"purple\">must</strong> be less than or equal to the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-subresourceRange-01488",\r
+ "text": " <code>subresourceRange.baseArrayLayer</code> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-subresourceRange-01725",\r
+ "text": " If <code>subresourceRange.layerCount</code> is not <code>VK_REMAINING_ARRAY_LAYERS</code>, <span class=\"eq\"><code>subresourceRange.baseArrayLayer</code> + <code>subresourceRange.layerCount</code></span> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01207",\r
+ "text": " If <code>image</code> has a depth/stencil format with both depth and stencil components, then the <code>aspectMask</code> member of <code>subresourceRange</code> <strong class=\"purple\">must</strong> include both <code>VK_IMAGE_ASPECT_DEPTH_BIT</code> and <code>VK_IMAGE_ASPECT_STENCIL_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01208",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01209",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01210",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01211",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_SAMPLED_BIT</code> or <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01212",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_SRC_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01213",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01932",\r
+ "text": " If <code>image</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkSampleLocationsInfoEXT\">VkSampleLocationsInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-srcAccessMask-parameter",\r
+ "text": " <code>srcAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-dstAccessMask-parameter",\r
+ "text": " <code>dstAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-parameter",\r
+ "text": " <code>oldLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-newLayout-parameter",\r
+ "text": " <code>newLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-subresourceRange-parameter",\r
+ "text": " <code>subresourceRange</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceRange</code> structure"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01199",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_CONCURRENT</code>, <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> both be <code>VK_QUEUE_FAMILY_IGNORED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01200",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code>, <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> either both be <code>VK_QUEUE_FAMILY_IGNORED</code>, or both be a valid queue family (see &amp;lt;&amp;lt;devsandqueues-queueprops&amp;gt;&amp;gt;)."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01381",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_CONCURRENT</code>, at least one of <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> be <code>VK_QUEUE_FAMILY_IGNORED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01766",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_CONCURRENT</code>, and one of <code>srcQueueFamilyIndex</code> and <code>dstQueueFamilyIndex</code> is <code>VK_QUEUE_FAMILY_IGNORED</code>, the other <strong class=\"purple\">must</strong> be <code>VK_QUEUE_FAMILY_IGNORED</code> or a special queue family reserved for external memory transfers, as described in &amp;lt;&amp;lt;synchronization-queue-transfers&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01201",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code> and <code>srcQueueFamilyIndex</code> is <code>VK_QUEUE_FAMILY_IGNORED</code>, <code>dstQueueFamilyIndex</code> <strong class=\"purple\">must</strong> also be <code>VK_QUEUE_FAMILY_IGNORED</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01767",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code> and <code>srcQueueFamilyIndex</code> is not <code>VK_QUEUE_FAMILY_IGNORED</code>, it <strong class=\"purple\">must</strong> be a valid queue family or a special queue family reserved for external memory transfers, as described in &amp;lt;&amp;lt;synchronization-queue-transfers&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01768",\r
+ "text": " If <code>image</code> was created with a sharing mode of <code>VK_SHARING_MODE_EXCLUSIVE</code> and <code>dstQueueFamilyIndex</code> is not <code>VK_QUEUE_FAMILY_IGNORED</code>, it <strong class=\"purple\">must</strong> be a valid queue family or a special queue family reserved for external memory transfers, as described in &amp;lt;&amp;lt;synchronization-queue-transfers&amp;gt;&amp;gt;."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01671",\r
+ "text": " If <code>image</code> has a single-plane color format or is not <em>disjoint</em>, then the <code>aspectMask</code> member of <code>subresourceRange</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_COLOR_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01672",\r
+ "text": " If <code>image</code> has a multi-planar format and the image is <em>disjoint</em>, then the <code>aspectMask</code> member of <code>subresourceRange</code> <strong class=\"purple\">must</strong> include either at least one of <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, and <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>; or <strong class=\"purple\">must</strong> include <code>VK_IMAGE_ASPECT_COLOR_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-image-01673",\r
+ "text": " If <code>image</code> has a multi-planar format with only two planes, then the <code>aspectMask</code> member of <code>subresourceRange</code> <strong class=\"purple\">must</strong> not include <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01658",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryBarrier-oldLayout-01659",\r
+ "text": " If either <code>oldLayout</code> or <code>newLayout</code> is <code>VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL</code> then <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code> set"\r
+ }\r
+ ]\r
+ },\r
+ "vkQueueWaitIdle": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkQueueWaitIdle-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkDeviceWaitIdle": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDeviceWaitIdle-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateRenderPass": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateRenderPass-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateRenderPass-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkRenderPassCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateRenderPass-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateRenderPass-pRenderPass-parameter",\r
+ "text": " <code>pRenderPass</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkRenderPass</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkRenderPassCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-None-00832",\r
+ "text": " If any two subpasses operate on attachments with overlapping ranges of the same <code>VkDeviceMemory</code> object, and at least one subpass writes to that area of <code>VkDeviceMemory</code>, a subpass dependency <strong class=\"purple\">must</strong> be included (either directly or via some intermediate subpasses) between them"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-attachment-00833",\r
+ "text": " If the <code>attachment</code> member of any element of <code>pInputAttachments</code>, <code>pColorAttachments</code>, <code>pResolveAttachments</code> or <code>pDepthStencilAttachment</code>, or the attachment indexed by any element of <code>pPreserveAttachments</code> in any element of <code>pSubpasses</code> is bound to a range of a <code>VkDeviceMemory</code> object that overlaps with any other attachment in any subpass (including the same subpass), the <code>VkAttachmentDescription</code> structures describing them <strong class=\"purple\">must</strong> include <code>VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT</code> in <code>flags</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-attachment-00834",\r
+ "text": " If the <code>attachment</code> member of any element of <code>pInputAttachments</code>, <code>pColorAttachments</code>, <code>pResolveAttachments</code> or <code>pDepthStencilAttachment</code>, or any element of <code>pPreserveAttachments</code> in any element of <code>pSubpasses</code> is not <code>VK_ATTACHMENT_UNUSED</code>, it <strong class=\"purple\">must</strong> be less than <code>attachmentCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pPreserveAttachments-00835",\r
+ "text": " The value of each element of the <code>pPreserveAttachments</code> member in each element of <code>pSubpasses</code> <strong class=\"purple\">must</strong> not be <code>VK_ATTACHMENT_UNUSED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pAttachments-00836",\r
+ "text": " For any member of <code>pAttachments</code> with a <code>loadOp</code> equal to <code>VK_ATTACHMENT_LOAD_OP_CLEAR</code>, the first use of that attachment <strong class=\"purple\">must</strong> not specify a <code>layout</code> equal to <code>VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pDependencies-00837",\r
+ "text": " For any element of <code>pDependencies</code>, if the <code>srcSubpass</code> is not <code>VK_SUBPASS_EXTERNAL</code>, all stage flags included in the <code>srcStageMask</code> member of that dependency <strong class=\"purple\">must</strong> be a pipeline stage supported by the &amp;lt;&amp;lt;synchronization-pipeline-stages-types, pipeline&amp;gt;&amp;gt; identified by the <code>pipelineBindPoint</code> member of the source subpass."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pDependencies-00838",\r
+ "text": " For any element of <code>pDependencies</code>, if the <code>dstSubpass</code> is not <code>VK_SUBPASS_EXTERNAL</code>, all stage flags included in the <code>dstStageMask</code> member of that dependency <strong class=\"purple\">must</strong> be a pipeline stage supported by the &amp;lt;&amp;lt;synchronization-pipeline-stages-types, pipeline&amp;gt;&amp;gt; identified by the <code>pipelineBindPoint</code> member of the source subpass."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkRenderPassInputAttachmentAspectCreateInfo\">VkRenderPassInputAttachmentAspectCreateInfo</a> or <a href=\"#VkRenderPassMultiviewCreateInfo\">VkRenderPassMultiviewCreateInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pAttachments-parameter",\r
+ "text": " If <code>attachmentCount</code> is not <code>0</code>, <code>pAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>attachmentCount</code> valid <code>VkAttachmentDescription</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pSubpasses-parameter",\r
+ "text": " <code>pSubpasses</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>subpassCount</code> valid <code>VkSubpassDescription</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pDependencies-parameter",\r
+ "text": " If <code>dependencyCount</code> is not <code>0</code>, <code>pDependencies</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dependencyCount</code> valid <code>VkSubpassDependency</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-subpassCount-arraylength",\r
+ "text": " <code>subpassCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pAttachments-01566",\r
+ "text": " For any member of <code>pAttachments</code> with a <code>loadOp</code> equal to <code>VK_ATTACHMENT_LOAD_OP_CLEAR</code>, the first use of that attachment <strong class=\"purple\">must</strong> not specify a <code>layout</code> equal to <code>VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pAttachments-01567",\r
+ "text": " For any member of <code>pAttachments</code> with a <code>stencilLoadOp</code> equal to <code>VK_ATTACHMENT_LOAD_OP_CLEAR</code>, the first use of that attachment <strong class=\"purple\">must</strong> not specify a <code>layout</code> equal to <code>VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pNext-01926",\r
+ "text": " If the <code>pNext</code> chain includes an instance of <a href=\"#VkRenderPassInputAttachmentAspectCreateInfo\">VkRenderPassInputAttachmentAspectCreateInfo</a>, the <code>subpass</code> member of each element of its <code>pAspectReferences</code> member <strong class=\"purple\">must</strong> be less than <code>subpassCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pNext-01927",\r
+ "text": " If the <code>pNext</code> chain includes an instance of <a href=\"#VkRenderPassInputAttachmentAspectCreateInfo\">VkRenderPassInputAttachmentAspectCreateInfo</a>, the <code>inputAttachmentIndex</code> member of each element of its <code>pAspectReferences</code> member <strong class=\"purple\">must</strong> be less than the value of <code>inputAttachmentCount</code> in the member of <code>pSubpasses</code> identified by its <code>subpass</code> member"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pNext-01928",\r
+ "text": " If the <code>pNext</code> chain includes an instance of <a href=\"#VkRenderPassMultiviewCreateInfo\">VkRenderPassMultiviewCreateInfo</a>, and its <code>subpassCount</code> member is not zero, that member <strong class=\"purple\">must</strong> be equal to the value of <code>subpassCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pNext-01929",\r
+ "text": " If the <code>pNext</code> chain includes an instance of <a href=\"#VkRenderPassMultiviewCreateInfo\">VkRenderPassMultiviewCreateInfo</a>, if its <code>dependencyCount</code> member is not zero, it <strong class=\"purple\">must</strong> be equal to <code>dependencyCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassCreateInfo-pNext-01930",\r
+ "text": " If the <code>pNext</code> chain includes an instance of <a href=\"#VkRenderPassMultiviewCreateInfo\">VkRenderPassMultiviewCreateInfo</a>, for each non-zero element of <code>pViewOffsets</code>, the <code>srcSubpass</code> and <code>dstSubpass</code> members of <code>pDependencies</code> at the same index <strong class=\"purple\">must</strong> not be equal"\r
+ }\r
+ ]\r
+ },\r
+ "VkRenderPassMultiviewCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassMultiviewCreateInfo-pCorrelationMasks-00841",\r
+ "text": " Each view index <strong class=\"purple\">must</strong> not be set in more than one element of <code>pCorrelationMasks</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassMultiviewCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassMultiviewCreateInfo-pViewMasks-parameter",\r
+ "text": " If <code>subpassCount</code> is not <code>0</code>, <code>pViewMasks</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>subpassCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassMultiviewCreateInfo-pViewOffsets-parameter",\r
+ "text": " If <code>dependencyCount</code> is not <code>0</code>, <code>pViewOffsets</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dependencyCount</code> <code>int32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassMultiviewCreateInfo-pCorrelationMasks-parameter",\r
+ "text": " If <code>correlationMaskCount</code> is not <code>0</code>, <code>pCorrelationMasks</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>correlationMaskCount</code> <code>uint32_t</code> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkAttachmentDescription": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-finalLayout-00843",\r
+ "text": " <code>finalLayout</code> <strong class=\"purple\">must</strong> not be <code>VK_IMAGE_LAYOUT_UNDEFINED</code> or <code>VK_IMAGE_LAYOUT_PREINITIALIZED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAttachmentDescriptionFlagBits\">VkAttachmentDescriptionFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-samples-parameter",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-loadOp-parameter",\r
+ "text": " <code>loadOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkAttachmentLoadOp\">VkAttachmentLoadOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-storeOp-parameter",\r
+ "text": " <code>storeOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkAttachmentStoreOp\">VkAttachmentStoreOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-stencilLoadOp-parameter",\r
+ "text": " <code>stencilLoadOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkAttachmentLoadOp\">VkAttachmentLoadOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-stencilStoreOp-parameter",\r
+ "text": " <code>stencilStoreOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkAttachmentStoreOp\">VkAttachmentStoreOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-initialLayout-parameter",\r
+ "text": " <code>initialLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentDescription-finalLayout-parameter",\r
+ "text": " <code>finalLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkRenderPassInputAttachmentAspectCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassInputAttachmentAspectCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassInputAttachmentAspectCreateInfo-pAspectReferences-parameter",\r
+ "text": " <code>pAspectReferences</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>aspectReferenceCount</code> valid <code>VkInputAttachmentAspectReference</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassInputAttachmentAspectCreateInfo-aspectReferenceCount-arraylength",\r
+ "text": " <code>aspectReferenceCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkInputAttachmentAspectReference": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkInputAttachmentAspectReference-pCreateInfo-01568",\r
+ "text": " There <strong class=\"purple\">must</strong> be an input attachment at <code>pCreateInfo</code>::<code>pSubpasses</code>[<code>subpass</code>].<code>pInputAttachments</code>[<code>inputAttachmentIndex</code>]."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInputAttachmentAspectReference-None-01569",\r
+ "text": " The specified input attachment <strong class=\"purple\">must</strong> have more than one aspect mask."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInputAttachmentAspectReference-aspectMask-01570",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> be a subset of the aspect masks in the specified input attachment."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInputAttachmentAspectReference-aspectMask-parameter",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkInputAttachmentAspectReference-aspectMask-requiredbitmask",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSubpassDescription": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pipelineBindPoint-00844",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-colorAttachmentCount-00845",\r
+ "text": " <code>colorAttachmentCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxColorAttachments</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-loadOp-00846",\r
+ "text": " If the first use of an attachment in this render pass is as an input attachment, and the attachment is not also used as a color or depth/stencil attachment in the same subpass, then <code>loadOp</code> <strong class=\"purple\">must</strong> not be <code>VK_ATTACHMENT_LOAD_OP_CLEAR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pResolveAttachments-00847",\r
+ "text": " If <code>pResolveAttachments</code> is not <code>NULL</code>, for each resolve attachment that does not have the value <code>VK_ATTACHMENT_UNUSED</code>, the corresponding color attachment <strong class=\"purple\">must</strong> not have the value <code>VK_ATTACHMENT_UNUSED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pResolveAttachments-00848",\r
+ "text": " If <code>pResolveAttachments</code> is not <code>NULL</code>, the sample count of each element of <code>pColorAttachments</code> <strong class=\"purple\">must</strong> be anything other than <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pResolveAttachments-00849",\r
+ "text": " Each element of <code>pResolveAttachments</code> <strong class=\"purple\">must</strong> have a sample count of <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pResolveAttachments-00850",\r
+ "text": " Each element of <code>pResolveAttachments</code> <strong class=\"purple\">must</strong> have the same <a href=\"#VkFormat\">VkFormat</a> as its corresponding color attachment"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pColorAttachments-01417",\r
+ "text": " All attachments in <code>pColorAttachments</code> that are not <code>VK_ATTACHMENT_UNUSED</code> <strong class=\"purple\">must</strong> have the same sample count"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-None-00852",\r
+ "text": " If any input attachments are <code>VK_ATTACHMENT_UNUSED</code>, then any pipelines bound during the subpass <strong class=\"purple\">must</strong> not access those input attachments from the fragment shader"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-attachment-00853",\r
+ "text": " The <code>attachment</code> member of each element of <code>pPreserveAttachments</code> <strong class=\"purple\">must</strong> not be <code>VK_ATTACHMENT_UNUSED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pPreserveAttachments-00854",\r
+ "text": " Each element of <code>pPreserveAttachments</code> <strong class=\"purple\">must</strong> not also be an element of any other member of the subpass description"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-layout-00855",\r
+ "text": " If any attachment is used as both an input attachment and a color or depth/stencil attachment, then each use <strong class=\"purple\">must</strong> use the same <code>layout</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSubpassDescriptionFlagBits\">VkSubpassDescriptionFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pipelineBindPoint-parameter",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineBindPoint\">VkPipelineBindPoint</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pInputAttachments-parameter",\r
+ "text": " If <code>inputAttachmentCount</code> is not <code>0</code>, <code>pInputAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>inputAttachmentCount</code> valid <code>VkAttachmentReference</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pColorAttachments-parameter",\r
+ "text": " If <code>colorAttachmentCount</code> is not <code>0</code>, <code>pColorAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>colorAttachmentCount</code> valid <code>VkAttachmentReference</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pResolveAttachments-parameter",\r
+ "text": " If <code>colorAttachmentCount</code> is not <code>0</code>, and <code>pResolveAttachments</code> is not <code>NULL</code>, <code>pResolveAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>colorAttachmentCount</code> valid <code>VkAttachmentReference</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pDepthStencilAttachment-parameter",\r
+ "text": " If <code>pDepthStencilAttachment</code> is not <code>NULL</code>, <code>pDepthStencilAttachment</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAttachmentReference</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pPreserveAttachments-parameter",\r
+ "text": " If <code>preserveAttachmentCount</code> is not <code>0</code>, <code>pPreserveAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>preserveAttachmentCount</code> <code>uint32_t</code> values"\r
+ }\r
+ ],\r
+ "(VK_AMD_mixed_attachment_samples)": [\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pColorAttachments-01506",\r
+ "text": " All attachments in <code>pColorAttachments</code> that are not <code>VK_ATTACHMENT_UNUSED</code> <strong class=\"purple\">must</strong> have a sample count that is smaller than or equal to the sample count of <code>pDepthStencilAttachment</code> if it is not <code>VK_ATTACHMENT_UNUSED</code>"\r
+ }\r
+ ],\r
+ "!(VK_AMD_mixed_attachment_samples)+!(VK_NV_framebuffer_mixed_samples)": [\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-pDepthStencilAttachment-01418",\r
+ "text": " If <code>pDepthStencilAttachment</code> is not <code>VK_ATTACHMENT_UNUSED</code> and any attachments in <code>pColorAttachments</code> are not <code>VK_ATTACHMENT_UNUSED</code>, they <strong class=\"purple\">must</strong> have the same sample count"\r
+ }\r
+ ],\r
+ "(VK_NVX_multiview_per_view_attributes)": [\r
+ {\r
+ "vuid": "VUID-VkSubpassDescription-flags-00856",\r
+ "text": " If <code>flags</code> includes <code>VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX</code>, it <strong class=\"purple\">must</strong> also include <code>VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX</code>."\r
+ }\r
+ ]\r
+ },\r
+ "VkAttachmentReference": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkAttachmentReference-layout-00857",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> not be <code>VK_IMAGE_LAYOUT_UNDEFINED</code> or <code>VK_IMAGE_LAYOUT_PREINITIALIZED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentReference-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkSubpassDependency": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcSubpass-00858",\r
+ "text": " If <code>srcSubpass</code> is not <code>VK_SUBPASS_EXTERNAL</code>, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not include <code>VK_PIPELINE_STAGE_HOST_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstSubpass-00859",\r
+ "text": " If <code>dstSubpass</code> is not <code>VK_SUBPASS_EXTERNAL</code>, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not include <code>VK_PIPELINE_STAGE_HOST_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcStageMask-00860",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstStageMask-00861",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcStageMask-00862",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>srcStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstStageMask-00863",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>dstStageMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code> or <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcSubpass-00864",\r
+ "text": " <code>srcSubpass</code> <strong class=\"purple\">must</strong> be less than or equal to <code>dstSubpass</code>, unless one of them is <code>VK_SUBPASS_EXTERNAL</code>, to avoid cyclic dependencies and ensure a valid execution order"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcSubpass-00865",\r
+ "text": " <code>srcSubpass</code> and <code>dstSubpass</code> <strong class=\"purple\">must</strong> not both be equal to <code>VK_SUBPASS_EXTERNAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcSubpass-00866",\r
+ "text": " If <code>srcSubpass</code> is equal to <code>dstSubpass</code>, <code>srcStageMask</code> and <code>dstStageMask</code> <strong class=\"purple\">must</strong> only contain one of <code>VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT</code>, <code>VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT</code>, <code>VK_PIPELINE_STAGE_VERTEX_INPUT_BIT</code>, <code>VK_PIPELINE_STAGE_VERTEX_SHADER_BIT</code>, <code>VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT</code>, <code>VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT</code>, <code>VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT</code>, <code>VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT</code>, <code>VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT</code>, <code>VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT</code>, <code>VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT</code>, <code>VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT</code>, or <code>VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcSubpass-00867",\r
+ "text": " If <code>srcSubpass</code> is equal to <code>dstSubpass</code> and not all of the stages in <code>srcStageMask</code> and <code>dstStageMask</code> are &amp;lt;&amp;lt;synchronization-framebuffer-regions,framebuffer-space stages&amp;gt;&amp;gt;, the &amp;lt;&amp;lt;synchronization-pipeline-stages-order, logically latest&amp;gt;&amp;gt; pipeline stage in <code>srcStageMask</code> <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;synchronization-pipeline-stages-order, logically earlier&amp;gt;&amp;gt; than or equal to the &amp;lt;&amp;lt;synchronization-pipeline-stages-order, logically earliest&amp;gt;&amp;gt; pipeline stage in <code>dstStageMask</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcAccessMask-00868",\r
+ "text": " Any access flag included in <code>srcAccessMask</code> <strong class=\"purple\">must</strong> be supported by one of the pipeline stages in <code>srcStageMask</code>, as specified in the &amp;lt;&amp;lt;synchronization-access-types-supported, table of supported access types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstAccessMask-00869",\r
+ "text": " Any access flag included in <code>dstAccessMask</code> <strong class=\"purple\">must</strong> be supported by one of the pipeline stages in <code>dstStageMask</code>, as specified in the &amp;lt;&amp;lt;synchronization-access-types-supported, table of supported access types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcStageMask-parameter",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcStageMask-requiredbitmask",\r
+ "text": " <code>srcStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstStageMask-parameter",\r
+ "text": " <code>dstStageMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstStageMask-requiredbitmask",\r
+ "text": " <code>dstStageMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcAccessMask-parameter",\r
+ "text": " <code>srcAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dstAccessMask-parameter",\r
+ "text": " <code>dstAccessMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkAccessFlagBits\">VkAccessFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dependencyFlags-parameter",\r
+ "text": " <code>dependencyFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDependencyFlagBits\">VkDependencyFlagBits</a> values"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dependencyFlags-00870",\r
+ "text": " If <code>dependencyFlags</code> includes <code>VK_DEPENDENCY_VIEW_LOCAL_BIT</code>, then both <code>srcSubpass</code> and <code>dstSubpass</code> <strong class=\"purple\">must</strong> not equal <code>VK_SUBPASS_EXTERNAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-dependencyFlags-00871",\r
+ "text": " If <code>dependencyFlags</code> includes <code>VK_DEPENDENCY_VIEW_LOCAL_BIT</code>, then the render pass <strong class=\"purple\">must</strong> have multiview enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassDependency-srcSubpass-00872",\r
+ "text": " If <code>srcSubpass</code> equals <code>dstSubpass</code> and that subpass has more than one bit set in the view mask, then <code>dependencyFlags</code> <strong class=\"purple\">must</strong> include <code>VK_DEPENDENCY_VIEW_LOCAL_BIT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyRenderPass": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-renderPass-00873",\r
+ "text": " All submitted commands that refer to <code>renderPass</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-renderPass-00874",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>renderPass</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-renderPass-00875",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>renderPass</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-renderPass-parameter",\r
+ "text": " If <code>renderPass</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>renderPass</code> <strong class=\"purple\">must</strong> be a valid <code>VkRenderPass</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyRenderPass-renderPass-parent",\r
+ "text": " If <code>renderPass</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateFramebuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateFramebuffer-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateFramebuffer-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkFramebufferCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateFramebuffer-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateFramebuffer-pFramebuffer-parameter",\r
+ "text": " <code>pFramebuffer</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkFramebuffer</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkFramebufferCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-attachmentCount-00876",\r
+ "text": " <code>attachmentCount</code> <strong class=\"purple\">must</strong> be equal to the attachment count specified in <code>renderPass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00877",\r
+ "text": " Each element of <code>pAttachments</code> that is used as a color attachment or resolve attachment by <code>renderPass</code> <strong class=\"purple\">must</strong> have been created with a <code>usage</code> value including <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00878",\r
+ "text": " Each element of <code>pAttachments</code> that is used as a depth/stencil attachment by <code>renderPass</code> <strong class=\"purple\">must</strong> have been created with a <code>usage</code> value including <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00879",\r
+ "text": " Each element of <code>pAttachments</code> that is used as an input attachment by <code>renderPass</code> <strong class=\"purple\">must</strong> have been created with a <code>usage</code> value including <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00880",\r
+ "text": " Each element of <code>pAttachments</code> <strong class=\"purple\">must</strong> have been created with an <a href=\"#VkFormat\">VkFormat</a> value that matches the <a href=\"#VkFormat\">VkFormat</a> specified by the corresponding <code>VkAttachmentDescription</code> in <code>renderPass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00881",\r
+ "text": " Each element of <code>pAttachments</code> <strong class=\"purple\">must</strong> have been created with a <code>samples</code> value that matches the <code>samples</code> value specified by the corresponding <code>VkAttachmentDescription</code> in <code>renderPass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00882",\r
+ "text": " Each element of <code>pAttachments</code> <strong class=\"purple\">must</strong> have dimensions at least as large as the corresponding framebuffer dimension"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00883",\r
+ "text": " Each element of <code>pAttachments</code> <strong class=\"purple\">must</strong> only specify a single mip level"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00884",\r
+ "text": " Each element of <code>pAttachments</code> <strong class=\"purple\">must</strong> have been created with the identity swizzle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-width-00885",\r
+ "text": " <code>width</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-width-00886",\r
+ "text": " <code>width</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxFramebufferWidth</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-height-00887",\r
+ "text": " <code>height</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-height-00888",\r
+ "text": " <code>height</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxFramebufferHeight</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-layers-00889",\r
+ "text": " <code>layers</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-layers-00890",\r
+ "text": " <code>layers</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxFramebufferLayers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-renderPass-parameter",\r
+ "text": " <code>renderPass</code> <strong class=\"purple\">must</strong> be a valid <code>VkRenderPass</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-parameter",\r
+ "text": " If <code>attachmentCount</code> is not <code>0</code>, <code>pAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>attachmentCount</code> valid <code>VkImageView</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-commonparent",\r
+ "text": " Both of <code>renderPass</code>, and the elements of <code>pAttachments</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkFramebufferCreateInfo-pAttachments-00891",\r
+ "text": " Each element of <code>pAttachments</code> that is a 2D or 2D array image view taken from a 3D image <strong class=\"purple\">must</strong> not be a depth/stencil format"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyFramebuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-framebuffer-00892",\r
+ "text": " All submitted commands that refer to <code>framebuffer</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-framebuffer-00893",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>framebuffer</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-framebuffer-00894",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>framebuffer</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-framebuffer-parameter",\r
+ "text": " If <code>framebuffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>framebuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkFramebuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyFramebuffer-framebuffer-parent",\r
+ "text": " If <code>framebuffer</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBeginRenderPass": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-00895",\r
+ "text": " If any of the <code>initialLayout</code> or <code>finalLayout</code> member of the <code>VkAttachmentDescription</code> structures or the <code>layout</code> member of the <code>VkAttachmentReference</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is <code>VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL</code> then the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-00897",\r
+ "text": " If any of the <code>initialLayout</code> or <code>finalLayout</code> member of the <code>VkAttachmentDescription</code> structures or the <code>layout</code> member of the <code>VkAttachmentReference</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is <code>VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL</code> then the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_SAMPLED_BIT</code> or <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-00898",\r
+ "text": " If any of the <code>initialLayout</code> or <code>finalLayout</code> member of the <code>VkAttachmentDescription</code> structures or the <code>layout</code> member of the <code>VkAttachmentReference</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> then the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_SRC_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-00899",\r
+ "text": " If any of the <code>initialLayout</code> or <code>finalLayout</code> member of the <code>VkAttachmentDescription</code> structures or the <code>layout</code> member of the <code>VkAttachmentReference</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> then the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-00900",\r
+ "text": " If any of the <code>initialLayout</code> members of the <code>VkAttachmentDescription</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is not <code>VK_IMAGE_LAYOUT_UNDEFINED</code>, then each such <code>initialLayout</code> <strong class=\"purple\">must</strong> be equal to the current layout of the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-srcStageMask-00901",\r
+ "text": " The <code>srcStageMask</code> and <code>dstStageMask</code> members of any element of the <code>pDependencies</code> member of <a href=\"#VkRenderPassCreateInfo\">VkRenderPassCreateInfo</a> used to create <code>renderPass</code> <strong class=\"purple\">must</strong> be supported by the capabilities of the queue family identified by the <code>queueFamilyIndex</code> member of the <a href=\"#VkCommandPoolCreateInfo\">VkCommandPoolCreateInfo</a> used to create the command pool which <code>commandBuffer</code> was allocated from."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-pRenderPassBegin-parameter",\r
+ "text": " <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkRenderPassBeginInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-contents-parameter",\r
+ "text": " <code>contents</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSubpassContents\">VkSubpassContents</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-bufferlevel",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a primary <code>VkCommandBuffer</code>"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-00896",\r
+ "text": " If any of the <code>initialLayout</code> or <code>finalLayout</code> member of the <code>VkAttachmentDescription</code> structures or the <code>layout</code> member of the <code>VkAttachmentReference</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL</code>, or <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> then the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code> set"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginRenderPass-initialLayout-01758",\r
+ "text": " If any of the <code>initialLayout</code> or <code>finalLayout</code> member of the <code>VkAttachmentDescription</code> structures or the <code>layout</code> member of the <code>VkAttachmentReference</code> structures specified when creating the render pass specified in the <code>renderPass</code> member of <code>pRenderPassBegin</code> is <code>VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL</code>, or <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> then the corresponding attachment image subresource of the framebuffer specified in the <code>framebuffer</code> member of <code>pRenderPassBegin</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code> set"\r
+ }\r
+ ]\r
+ },\r
+ "VkRenderPassBeginInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-clearValueCount-00902",\r
+ "text": " <code>clearValueCount</code> <strong class=\"purple\">must</strong> be greater than the largest attachment index in <code>renderPass</code> that specifies a <code>loadOp</code> (or <code>stencilLoadOp</code>, if the attachment has a depth/stencil format) of <code>VK_ATTACHMENT_LOAD_OP_CLEAR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-clearValueCount-00903",\r
+ "text": " If <code>clearValueCount</code> is not <code>0</code>, <code>pClearValues</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>clearValueCount</code> valid <code>VkClearValue</code> unions"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-renderPass-00904",\r
+ "text": " <code>renderPass</code> <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkFramebufferCreateInfo</code> structure specified when creating <code>framebuffer</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceGroupRenderPassBeginInfo\">VkDeviceGroupRenderPassBeginInfo</a> or <a href=\"#VkRenderPassSampleLocationsBeginInfoEXT\">VkRenderPassSampleLocationsBeginInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-renderPass-parameter",\r
+ "text": " <code>renderPass</code> <strong class=\"purple\">must</strong> be a valid <code>VkRenderPass</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-framebuffer-parameter",\r
+ "text": " <code>framebuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkFramebuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassBeginInfo-commonparent",\r
+ "text": " Both of <code>framebuffer</code>, and <code>renderPass</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkRenderPassSampleLocationsBeginInfoEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkRenderPassSampleLocationsBeginInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassSampleLocationsBeginInfoEXT-pAttachmentInitialSampleLocations-parameter",\r
+ "text": " If <code>attachmentInitialSampleLocationsCount</code> is not <code>0</code>, <code>pAttachmentInitialSampleLocations</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>attachmentInitialSampleLocationsCount</code> valid <code>VkAttachmentSampleLocationsEXT</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRenderPassSampleLocationsBeginInfoEXT-pPostSubpassSampleLocations-parameter",\r
+ "text": " If <code>postSubpassSampleLocationsCount</code> is not <code>0</code>, <code>pPostSubpassSampleLocations</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>postSubpassSampleLocationsCount</code> valid <code>VkSubpassSampleLocationsEXT</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkAttachmentSampleLocationsEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkAttachmentSampleLocationsEXT-attachmentIndex-01531",\r
+ "text": " <code>attachmentIndex</code> <strong class=\"purple\">must</strong> be less than the <code>attachmentCount</code> specified in <a href=\"#VkRenderPassCreateInfo\">VkRenderPassCreateInfo</a> the render pass specified by <a href=\"#VkRenderPassBeginInfo\">VkRenderPassBeginInfo</a>::<code>renderPass</code> was created with"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAttachmentSampleLocationsEXT-sampleLocationsInfo-parameter",\r
+ "text": " <code>sampleLocationsInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkSampleLocationsInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkSubpassSampleLocationsEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkSubpassSampleLocationsEXT-subpassIndex-01532",\r
+ "text": " <code>subpassIndex</code> <strong class=\"purple\">must</strong> be less than the <code>subpassCount</code> specified in <a href=\"#VkRenderPassCreateInfo\">VkRenderPassCreateInfo</a> the render pass specified by <a href=\"#VkRenderPassBeginInfo\">VkRenderPassBeginInfo</a>::<code>renderPass</code> was created with"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSubpassSampleLocationsEXT-sampleLocationsInfo-parameter",\r
+ "text": " <code>sampleLocationsInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkSampleLocationsInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupRenderPassBeginInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupRenderPassBeginInfo-deviceMask-00905",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> be a valid device mask value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupRenderPassBeginInfo-deviceMask-00906",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> not be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupRenderPassBeginInfo-deviceMask-00907",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> be a subset of the command buffer’s initial device mask"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupRenderPassBeginInfo-deviceRenderAreaCount-00908",\r
+ "text": " <code>deviceRenderAreaCount</code> <strong class=\"purple\">must</strong> either be zero or equal to the number of physical devices in the logical device."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupRenderPassBeginInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupRenderPassBeginInfo-pDeviceRenderAreas-parameter",\r
+ "text": " If <code>deviceRenderAreaCount</code> is not <code>0</code>, <code>pDeviceRenderAreas</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>deviceRenderAreaCount</code> <code>VkRect2D</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetRenderAreaGranularity": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetRenderAreaGranularity-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRenderAreaGranularity-renderPass-parameter",\r
+ "text": " <code>renderPass</code> <strong class=\"purple\">must</strong> be a valid <code>VkRenderPass</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRenderAreaGranularity-pGranularity-parameter",\r
+ "text": " <code>pGranularity</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkExtent2D</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRenderAreaGranularity-renderPass-parent",\r
+ "text": " <code>renderPass</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdNextSubpass": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-None-00909",\r
+ "text": " The current subpass index <strong class=\"purple\">must</strong> be less than the number of subpasses in the render pass minus one"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-contents-parameter",\r
+ "text": " <code>contents</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSubpassContents\">VkSubpassContents</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdNextSubpass-bufferlevel",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a primary <code>VkCommandBuffer</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdEndRenderPass": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdEndRenderPass-None-00910",\r
+ "text": " The current subpass index <strong class=\"purple\">must</strong> be equal to the number of subpasses in the render pass minus one"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndRenderPass-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndRenderPass-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndRenderPass-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndRenderPass-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndRenderPass-bufferlevel",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a primary <code>VkCommandBuffer</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateShaderModule": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateShaderModule-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateShaderModule-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkShaderModuleCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateShaderModule-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateShaderModule-pShaderModule-parameter",\r
+ "text": " <code>pShaderModule</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkShaderModule</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkShaderModuleCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-codeSize-01085",\r
+ "text": " <code>codeSize</code> <strong class=\"purple\">must</strong> be greater than 0"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01089",\r
+ "text": " <code>pCode</code> <strong class=\"purple\">must</strong> declare the <code>Shader</code> capability for SPIR-V code"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01090",\r
+ "text": " <code>pCode</code> <strong class=\"purple\">must</strong> not declare any capability that is not supported by the API, as described by the &amp;lt;&amp;lt;spirvenv-module-validation, Capabilities&amp;gt;&amp;gt; section of the &amp;lt;&amp;lt;spirvenv-capabilities,SPIR-V Environment&amp;gt;&amp;gt; appendix"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01091",\r
+ "text": " If <code>pCode</code> declares any of the capabilities listed as <strong class=\"purple\">optional</strong> in the &amp;lt;&amp;lt;spirvenv-capabilities-table,SPIR-V Environment&amp;gt;&amp;gt; appendix, the corresponding feature(s) <strong class=\"purple\">must</strong> be enabled."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkShaderModuleValidationCacheCreateInfoEXT\">VkShaderModuleValidationCacheCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-parameter",\r
+ "text": " <code>pCode</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of \\(codeSize \\over 4\\) <code>uint32_t</code> values"\r
+ }\r
+ ],\r
+ "!(VK_NV_glsl_shader)": [\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-codeSize-01086",\r
+ "text": " <code>codeSize</code> <strong class=\"purple\">must</strong> be a multiple of 4"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01087",\r
+ "text": " <code>pCode</code> <strong class=\"purple\">must</strong> point to valid SPIR-V code, formatted and packed as described by the &amp;lt;&amp;lt;spirv-spec,Khronos SPIR-V Specification&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01088",\r
+ "text": " <code>pCode</code> <strong class=\"purple\">must</strong> adhere to the validation rules described by the &amp;lt;&amp;lt;spirvenv-module-validation, Validation Rules within a Module&amp;gt;&amp;gt; section of the &amp;lt;&amp;lt;spirvenv-capabilities,SPIR-V Environment&amp;gt;&amp;gt; appendix"\r
+ }\r
+ ],\r
+ "(VK_NV_glsl_shader)": [\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01376",\r
+ "text": " If <code>pCode</code> points to SPIR-V code, <code>codeSize</code> <strong class=\"purple\">must</strong> be a multiple of 4"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01377",\r
+ "text": " <code>pCode</code> <strong class=\"purple\">must</strong> point to either valid SPIR-V code, formatted and packed as described by the <a href=\"#spirv-spec\">Khronos SPIR-V Specification</a> or valid GLSL code which <strong class=\"purple\">must</strong> be written to the GL_KHR_vulkan_glsl extension specification"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01378",\r
+ "text": " If <code>pCode</code> points to SPIR-V code, that code <strong class=\"purple\">must</strong> adhere to the validation rules described by the &amp;lt;&amp;lt;spirvenv-module-validation, Validation Rules within a Module&amp;gt;&amp;gt; section of the &amp;lt;&amp;lt;spirvenv-capabilities,SPIR-V Environment&amp;gt;&amp;gt; appendix"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleCreateInfo-pCode-01379",\r
+ "text": " If <code>pCode</code> points to GLSL code, it <strong class=\"purple\">must</strong> be valid GLSL code written to the GL_KHR_vulkan_glsl GLSL extension specification"\r
+ }\r
+ ]\r
+ },\r
+ "VkShaderModuleValidationCacheCreateInfoEXT": {\r
+ "(VK_EXT_validation_cache)": [\r
+ {\r
+ "vuid": "VUID-VkShaderModuleValidationCacheCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkShaderModuleValidationCacheCreateInfoEXT-validationCache-parameter",\r
+ "text": " <code>validationCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkValidationCacheEXT</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyShaderModule": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyShaderModule-shaderModule-01092",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>shaderModule</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyShaderModule-shaderModule-01093",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>shaderModule</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyShaderModule-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyShaderModule-shaderModule-parameter",\r
+ "text": " If <code>shaderModule</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>shaderModule</code> <strong class=\"purple\">must</strong> be a valid <code>VkShaderModule</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyShaderModule-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyShaderModule-shaderModule-parent",\r
+ "text": " If <code>shaderModule</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateValidationCacheEXT": {\r
+ "(VK_EXT_validation_cache)": [\r
+ {\r
+ "vuid": "VUID-vkCreateValidationCacheEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateValidationCacheEXT-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkValidationCacheCreateInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateValidationCacheEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateValidationCacheEXT-pValidationCache-parameter",\r
+ "text": " <code>pValidationCache</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkValidationCacheEXT</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkValidationCacheCreateInfoEXT": {\r
+ "(VK_EXT_validation_cache)": [\r
+ {\r
+ "vuid": "VUID-VkValidationCacheCreateInfoEXT-initialDataSize-01534",\r
+ "text": " If <code>initialDataSize</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be equal to the size of <code>pInitialData</code>, as returned by <code>vkGetValidationCacheDataEXT</code> when <code>pInitialData</code> was originally retrieved"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationCacheCreateInfoEXT-initialDataSize-01535",\r
+ "text": " If <code>initialDataSize</code> is not <code>0</code>, <code>pInitialData</code> <strong class=\"purple\">must</strong> have been retrieved from a previous call to <code>vkGetValidationCacheDataEXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationCacheCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationCacheCreateInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationCacheCreateInfoEXT-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkValidationCacheCreateInfoEXT-pInitialData-parameter",\r
+ "text": " If <code>initialDataSize</code> is not <code>0</code>, <code>pInitialData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>initialDataSize</code> bytes"\r
+ }\r
+ ]\r
+ },\r
+ "vkMergeValidationCachesEXT": {\r
+ "(VK_EXT_validation_cache)": [\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-dstCache-01536",\r
+ "text": " <code>dstCache</code> <strong class=\"purple\">must</strong> not appear in the list of source caches"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-dstCache-parameter",\r
+ "text": " <code>dstCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkValidationCacheEXT</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-pSrcCaches-parameter",\r
+ "text": " <code>pSrcCaches</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>srcCacheCount</code> valid <code>VkValidationCacheEXT</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-srcCacheCount-arraylength",\r
+ "text": " <code>srcCacheCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-dstCache-parent",\r
+ "text": " <code>dstCache</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergeValidationCachesEXT-pSrcCaches-parent",\r
+ "text": " Each element of <code>pSrcCaches</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetValidationCacheDataEXT": {\r
+ "(VK_EXT_validation_cache)": [\r
+ {\r
+ "vuid": "VUID-vkGetValidationCacheDataEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetValidationCacheDataEXT-validationCache-parameter",\r
+ "text": " <code>validationCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkValidationCacheEXT</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetValidationCacheDataEXT-pDataSize-parameter",\r
+ "text": " <code>pDataSize</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>size_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetValidationCacheDataEXT-pData-parameter",\r
+ "text": " If the value referenced by <code>pDataSize</code> is not <code>0</code>, and <code>pData</code> is not <code>NULL</code>, <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pDataSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetValidationCacheDataEXT-validationCache-parent",\r
+ "text": " <code>validationCache</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyValidationCacheEXT": {\r
+ "(VK_EXT_validation_cache)": [\r
+ {\r
+ "vuid": "VUID-vkDestroyValidationCacheEXT-validationCache-01537",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>validationCache</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyValidationCacheEXT-validationCache-01538",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>validationCache</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyValidationCacheEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyValidationCacheEXT-validationCache-parameter",\r
+ "text": " If <code>validationCache</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>validationCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkValidationCacheEXT</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyValidationCacheEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyValidationCacheEXT-validationCache-parent",\r
+ "text": " If <code>validationCache</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateComputePipelines": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-flags-00695",\r
+ "text": " If the <code>flags</code> member of any element of <code>pCreateInfos</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and the <code>basePipelineIndex</code> member of that same element is not <code>-1</code>, <code>basePipelineIndex</code> <strong class=\"purple\">must</strong> be less than the index into <code>pCreateInfos</code> that corresponds to that element"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-flags-00696",\r
+ "text": " If the <code>flags</code> member of any element of <code>pCreateInfos</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, the base pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT</code> flag set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-pipelineCache-parameter",\r
+ "text": " If <code>pipelineCache</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>pipelineCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineCache</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-pCreateInfos-parameter",\r
+ "text": " <code>pCreateInfos</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>createInfoCount</code> valid <code>VkComputePipelineCreateInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-pPipelines-parameter",\r
+ "text": " <code>pPipelines</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>createInfoCount</code> <code>VkPipeline</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-createInfoCount-arraylength",\r
+ "text": " <code>createInfoCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateComputePipelines-pipelineCache-parent",\r
+ "text": " If <code>pipelineCache</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkComputePipelineCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-flags-00697",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineIndex</code> is -1, <code>basePipelineHandle</code> <strong class=\"purple\">must</strong> be a valid handle to a compute <code>VkPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-flags-00698",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineHandle</code> is <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>basePipelineIndex</code> <strong class=\"purple\">must</strong> be a valid index into the calling command’s <code>pCreateInfos</code> parameter"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-flags-00699",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineIndex</code> is not -1, <code>basePipelineHandle</code> <strong class=\"purple\">must</strong> be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-flags-00700",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineHandle</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>basePipelineIndex</code> <strong class=\"purple\">must</strong> be -1"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-stage-00701",\r
+ "text": " The <code>stage</code> member of <code>stage</code> <strong class=\"purple\">must</strong> be <code>VK_SHADER_STAGE_COMPUTE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-stage-00702",\r
+ "text": " The shader code for the entry point identified by <code>stage</code> and the rest of the state identified by this structure <strong class=\"purple\">must</strong> adhere to the pipeline linking rules described in the &amp;lt;&amp;lt;interfaces,Shader Interfaces&amp;gt;&amp;gt; chapter"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-layout-00703",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;descriptorsets-pipelinelayout-consistency,consistent&amp;gt;&amp;gt; with the layout of the compute shader specified in <code>stage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-layout-01687",\r
+ "text": " The number of resources in <code>layout</code> accessible to the compute shader stage <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageResources</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineCreateFlagBits\">VkPipelineCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-stage-parameter",\r
+ "text": " <code>stage</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineShaderStageCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComputePipelineCreateInfo-commonparent",\r
+ "text": " Both of <code>basePipelineHandle</code>, and <code>layout</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineShaderStageCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00704",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>stage</code> <strong class=\"purple\">must</strong> not be <code>VK_SHADER_STAGE_GEOMETRY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00705",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>stage</code> <strong class=\"purple\">must</strong> not be <code>VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT</code> or <code>VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00706",\r
+ "text": " <code>stage</code> <strong class=\"purple\">must</strong> not be <code>VK_SHADER_STAGE_ALL_GRAPHICS</code>, or <code>VK_SHADER_STAGE_ALL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-pName-00707",\r
+ "text": " <code>pName</code> <strong class=\"purple\">must</strong> be the name of an <code>OpEntryPoint</code> in <code>module</code> with an execution model that matches <code>stage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-maxClipDistances-00708",\r
+ "text": " If the identified entry point includes any variable in its interface that is declared with the <code>ClipDistance</code> <code>BuiltIn</code> decoration, that variable <strong class=\"purple\">must</strong> not have an array size greater than <code>VkPhysicalDeviceLimits</code>::<code>maxClipDistances</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-maxCullDistances-00709",\r
+ "text": " If the identified entry point includes any variable in its interface that is declared with the <code>CullDistance</code> <code>BuiltIn</code> decoration, that variable <strong class=\"purple\">must</strong> not have an array size greater than <code>VkPhysicalDeviceLimits</code>::<code>maxCullDistances</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-maxCombinedClipAndCullDistances-00710",\r
+ "text": " If the identified entry point includes any variables in its interface that are declared with the <code>ClipDistance</code> or <code>CullDistance</code> <code>BuiltIn</code> decoration, those variables <strong class=\"purple\">must</strong> not have array sizes which sum to more than <code>VkPhysicalDeviceLimits</code>::<code>maxCombinedClipAndCullDistances</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-maxSampleMaskWords-00711",\r
+ "text": " If the identified entry point includes any variable in its interface that is declared with the <code>SampleMask</code> <code>BuiltIn</code> decoration, that variable <strong class=\"purple\">must</strong> not have an array size greater than <code>VkPhysicalDeviceLimits</code>::<code>maxSampleMaskWords</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00712",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_VERTEX_BIT</code>, the identified entry point <strong class=\"purple\">must</strong> not include any input variable in its interface that is decorated with <code>CullDistance</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00713",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT</code> or <code>VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT</code>, and the identified entry point has an <code>OpExecutionMode</code> instruction that specifies a patch size with <code>OutputVertices</code>, the patch size <strong class=\"purple\">must</strong> be greater than <code>0</code> and less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxTessellationPatchSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00714",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_GEOMETRY_BIT</code>, the identified entry point <strong class=\"purple\">must</strong> have an <code>OpExecutionMode</code> instruction that specifies a maximum output vertex count that is greater than <code>0</code> and less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxGeometryOutputVertices</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00715",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_GEOMETRY_BIT</code>, the identified entry point <strong class=\"purple\">must</strong> have an <code>OpExecutionMode</code> instruction that specifies an invocation count that is greater than <code>0</code> and less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxGeometryShaderInvocations</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00716",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_GEOMETRY_BIT</code>, and the identified entry point writes to <code>Layer</code> for any primitive, it <strong class=\"purple\">must</strong> write the same value to <code>Layer</code> for all vertices of a given primitive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00717",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_GEOMETRY_BIT</code>, and the identified entry point writes to <code>ViewportIndex</code> for any primitive, it <strong class=\"purple\">must</strong> write the same value to <code>ViewportIndex</code> for all vertices of a given primitive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00718",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_FRAGMENT_BIT</code>, the identified entry point <strong class=\"purple\">must</strong> not include any output variables in its interface decorated with <code>CullDistance</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-00719",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_FRAGMENT_BIT</code>, and the identified entry point writes to <code>FragDepth</code> in any execution path, it <strong class=\"purple\">must</strong> write to <code>FragDepth</code> in all execution paths"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-parameter",\r
+ "text": " <code>stage</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkShaderStageFlagBits\">VkShaderStageFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-module-parameter",\r
+ "text": " <code>module</code> <strong class=\"purple\">must</strong> be a valid <code>VkShaderModule</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-pName-parameter",\r
+ "text": " <code>pName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-pSpecializationInfo-parameter",\r
+ "text": " If <code>pSpecializationInfo</code> is not <code>NULL</code>, <code>pSpecializationInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSpecializationInfo</code> structure"\r
+ }\r
+ ],\r
+ "(VK_EXT_shader_stencil_export)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineShaderStageCreateInfo-stage-01511",\r
+ "text": " If <code>stage</code> is <code>VK_SHADER_STAGE_FRAGMENT_BIT</code>, and the identified entry point writes to <code>FragStencilRefEXT</code> in any execution path, it <strong class=\"purple\">must</strong> write to <code>FragStencilRefEXT</code> in all execution paths"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateGraphicsPipelines": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-flags-00720",\r
+ "text": " If the <code>flags</code> member of any element of <code>pCreateInfos</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and the <code>basePipelineIndex</code> member of that same element is not <code>-1</code>, <code>basePipelineIndex</code> <strong class=\"purple\">must</strong> be less than the index into <code>pCreateInfos</code> that corresponds to that element"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-flags-00721",\r
+ "text": " If the <code>flags</code> member of any element of <code>pCreateInfos</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, the base pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT</code> flag set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-pipelineCache-parameter",\r
+ "text": " If <code>pipelineCache</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>pipelineCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineCache</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-pCreateInfos-parameter",\r
+ "text": " <code>pCreateInfos</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>createInfoCount</code> valid <code>VkGraphicsPipelineCreateInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-pPipelines-parameter",\r
+ "text": " <code>pPipelines</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>createInfoCount</code> <code>VkPipeline</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-createInfoCount-arraylength",\r
+ "text": " <code>createInfoCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateGraphicsPipelines-pipelineCache-parent",\r
+ "text": " If <code>pipelineCache</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkGraphicsPipelineCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-flags-00722",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineIndex</code> is -1, <code>basePipelineHandle</code> <strong class=\"purple\">must</strong> be a valid handle to a graphics <code>VkPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-flags-00723",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineHandle</code> is <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>basePipelineIndex</code> <strong class=\"purple\">must</strong> be a valid index into the calling command’s <code>pCreateInfos</code> parameter"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-flags-00724",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineIndex</code> is not -1, <code>basePipelineHandle</code> <strong class=\"purple\">must</strong> be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-flags-00725",\r
+ "text": " If <code>flags</code> contains the <code>VK_PIPELINE_CREATE_DERIVATIVE_BIT</code> flag, and <code>basePipelineHandle</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>basePipelineIndex</code> <strong class=\"purple\">must</strong> be -1"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-stage-00726",\r
+ "text": " The <code>stage</code> member of each element of <code>pStages</code> <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-stage-00727",\r
+ "text": " The <code>stage</code> member of one element of <code>pStages</code> <strong class=\"purple\">must</strong> be <code>VK_SHADER_STAGE_VERTEX_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-stage-00728",\r
+ "text": " The <code>stage</code> member of each element of <code>pStages</code> <strong class=\"purple\">must</strong> not be <code>VK_SHADER_STAGE_COMPUTE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00729",\r
+ "text": " If <code>pStages</code> includes a tessellation control shader stage, it <strong class=\"purple\">must</strong> include a tessellation evaluation shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00730",\r
+ "text": " If <code>pStages</code> includes a tessellation evaluation shader stage, it <strong class=\"purple\">must</strong> include a tessellation control shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00731",\r
+ "text": " If <code>pStages</code> includes a tessellation control shader stage and a tessellation evaluation shader stage, <code>pTessellationState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineTessellationStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00732",\r
+ "text": " If <code>pStages</code> includes tessellation shader stages, the shader code of at least one stage <strong class=\"purple\">must</strong> contain an <code>OpExecutionMode</code> instruction that specifies the type of subdivision in the pipeline"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00733",\r
+ "text": " If <code>pStages</code> includes tessellation shader stages, and the shader code of both stages contain an <code>OpExecutionMode</code> instruction that specifies the type of subdivision in the pipeline, they <strong class=\"purple\">must</strong> both specify the same subdivision mode"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00734",\r
+ "text": " If <code>pStages</code> includes tessellation shader stages, the shader code of at least one stage <strong class=\"purple\">must</strong> contain an <code>OpExecutionMode</code> instruction that specifies the output patch size in the pipeline"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00735",\r
+ "text": " If <code>pStages</code> includes tessellation shader stages, and the shader code of both contain an <code>OpExecutionMode</code> instruction that specifies the out patch size in the pipeline, they <strong class=\"purple\">must</strong> both specify the same patch size"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00736",\r
+ "text": " If <code>pStages</code> includes tessellation shader stages, the <code>topology</code> member of <code>pInputAssembly</code> <strong class=\"purple\">must</strong> be <code>VK_PRIMITIVE_TOPOLOGY_PATCH_LIST</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-topology-00737",\r
+ "text": " If the <code>topology</code> member of <code>pInputAssembly</code> is <code>VK_PRIMITIVE_TOPOLOGY_PATCH_LIST</code>, <code>pStages</code> <strong class=\"purple\">must</strong> include tessellation shader stages"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00738",\r
+ "text": " If <code>pStages</code> includes a geometry shader stage, and does not include any tessellation shader stages, its shader code <strong class=\"purple\">must</strong> contain an <code>OpExecutionMode</code> instruction that specifies an input primitive type that is &amp;lt;&amp;lt;shaders-geometry-execution, compatible&amp;gt;&amp;gt; with the primitive topology specified in <code>pInputAssembly</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00739",\r
+ "text": " If <code>pStages</code> includes a geometry shader stage, and also includes tessellation shader stages, its shader code <strong class=\"purple\">must</strong> contain an <code>OpExecutionMode</code> instruction that specifies an input primitive type that is &amp;lt;&amp;lt;shaders-geometry-execution, compatible&amp;gt;&amp;gt; with the primitive topology that is output by the tessellation stages"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00740",\r
+ "text": " If <code>pStages</code> includes a fragment shader stage and a geometry shader stage, and the fragment shader code reads from an input variable that is decorated with <code>PrimitiveID</code>, then the geometry shader code <strong class=\"purple\">must</strong> write to a matching output variable, decorated with <code>PrimitiveID</code>, in all execution paths"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00741",\r
+ "text": " If <code>pStages</code> includes a fragment shader stage, its shader code <strong class=\"purple\">must</strong> not read from any input attachment that is defined as <code>VK_ATTACHMENT_UNUSED</code> in <code>subpass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-00742",\r
+ "text": " The shader code for the entry points identified by <code>pStages</code>, and the rest of the state identified by this structure <strong class=\"purple\">must</strong> adhere to the pipeline linking rules described in the &amp;lt;&amp;lt;interfaces,Shader Interfaces&amp;gt;&amp;gt; chapter"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-00745",\r
+ "text": " If rasterization is not disabled and the subpass uses color attachments, then for each color attachment in the subpass the <code>blendEnable</code> member of the corresponding element of the <code>pAttachment</code> member of <code>pColorBlendState</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code> if the <code>format</code> of the attachment does not support color blend operations, as specified by the <code>VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-attachmentCount-00746",\r
+ "text": " If rasterization is not disabled and the subpass uses color attachments, the <code>attachmentCount</code> member of <code>pColorBlendState</code> <strong class=\"purple\">must</strong> be equal to the <code>colorAttachmentCount</code> used to create <code>subpass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-00747",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_VIEWPORT</code>, the <code>pViewports</code> member of <code>pViewportState</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pViewportState</code>::<code>viewportCount</code> <code>VkViewport</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-00748",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_SCISSOR</code>, the <code>pScissors</code> member of <code>pViewportState</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pViewportState</code>::<code>scissorCount</code> <code>VkRect2D</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-00749",\r
+ "text": " If the wide lines feature is not enabled, and no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_LINE_WIDTH</code>, the <code>lineWidth</code> member of <code>pRasterizationState</code> <strong class=\"purple\">must</strong> be <code>1.0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-rasterizerDiscardEnable-00750",\r
+ "text": " If the <code>rasterizerDiscardEnable</code> member of <code>pRasterizationState</code> is <code>VK_FALSE</code>, <code>pViewportState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineViewportStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-rasterizerDiscardEnable-00751",\r
+ "text": " If the <code>rasterizerDiscardEnable</code> member of <code>pRasterizationState</code> is <code>VK_FALSE</code>, <code>pMultisampleState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineMultisampleStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-rasterizerDiscardEnable-00752",\r
+ "text": " If the <code>rasterizerDiscardEnable</code> member of <code>pRasterizationState</code> is <code>VK_FALSE</code>, and <code>subpass</code> uses a depth/stencil attachment, <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineDepthStencilStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-rasterizerDiscardEnable-00753",\r
+ "text": " If the <code>rasterizerDiscardEnable</code> member of <code>pRasterizationState</code> is <code>VK_FALSE</code>, and <code>subpass</code> uses color attachments, <code>pColorBlendState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineColorBlendStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-00754",\r
+ "text": " If the depth bias clamping feature is not enabled, no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_DEPTH_BIAS</code>, and the <code>depthBiasEnable</code> member of <code>pRasterizationState</code> is <code>VK_TRUE</code>, the <code>depthBiasClamp</code> member of <code>pRasterizationState</code> <strong class=\"purple\">must</strong> be <code>0.0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-layout-00756",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;descriptorsets-pipelinelayout-consistency,consistent&amp;gt;&amp;gt; with all shaders specified in <code>pStages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-00758",\r
+ "text": " If <code>subpass</code> does not use any color and/or depth/stencil attachments, then the <code>rasterizationSamples</code> member of <code>pMultisampleState</code> <strong class=\"purple\">must</strong> follow the rules for a &amp;lt;&amp;lt;renderpass-noattachments, zero-attachment subpass&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-00759",\r
+ "text": " <code>subpass</code> <strong class=\"purple\">must</strong> be a valid subpass within <code>renderPass</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-layout-01688",\r
+ "text": " The number of resources in <code>layout</code> accessible to each shader stage that is used by the pipeline <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageResources</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineDiscardRectangleStateCreateInfoEXT\">VkPipelineDiscardRectangleStateCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkPipelineCreateFlagBits\">VkPipelineCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-parameter",\r
+ "text": " <code>pStages</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>stageCount</code> valid <code>VkPipelineShaderStageCreateInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pVertexInputState-parameter",\r
+ "text": " <code>pVertexInputState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineVertexInputStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pInputAssemblyState-parameter",\r
+ "text": " <code>pInputAssemblyState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineInputAssemblyStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pRasterizationState-parameter",\r
+ "text": " <code>pRasterizationState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineRasterizationStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicState-parameter",\r
+ "text": " If <code>pDynamicState</code> is not <code>NULL</code>, <code>pDynamicState</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineDynamicStateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-renderPass-parameter",\r
+ "text": " <code>renderPass</code> <strong class=\"purple\">must</strong> be a valid <code>VkRenderPass</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-stageCount-arraylength",\r
+ "text": " <code>stageCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-commonparent",\r
+ "text": " Each of <code>basePipelineHandle</code>, <code>layout</code>, and <code>renderPass</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-00743",\r
+ "text": " If rasterization is not disabled and <code>subpass</code> uses a depth/stencil attachment in <code>renderPass</code> that has a layout of <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> in the <code>VkAttachmentReference</code> defined by <code>subpass</code>, the <code>depthWriteEnable</code> member of <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-00744",\r
+ "text": " If rasterization is not disabled and <code>subpass</code> uses a depth/stencil attachment in <code>renderPass</code> that has a layout of <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> in the <code>VkAttachmentReference</code> defined by <code>subpass</code>, the <code>failOp</code>, <code>passOp</code> and <code>depthFailOp</code> members of each of the <code>front</code> and <code>back</code> members of <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be <code>VK_STENCIL_OP_KEEP</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-01756",\r
+ "text": " If rasterization is not disabled and <code>subpass</code> uses a depth/stencil attachment in <code>renderPass</code> that has a layout of <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL</code> in the <code>VkAttachmentReference</code> defined by <code>subpass</code>, the <code>depthWriteEnable</code> member of <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-01757",\r
+ "text": " If rasterization is not disabled and <code>subpass</code> uses a depth/stencil attachment in <code>renderPass</code> that has a layout of <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL</code> in the <code>VkAttachmentReference</code> defined by <code>subpass</code>, the <code>failOp</code>, <code>passOp</code> and <code>depthFailOp</code> members of each of the <code>front</code> and <code>back</code> members of <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be <code>VK_STENCIL_OP_KEEP</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pStages-01565",\r
+ "text": " If <code>pStages</code> includes a fragment shader stage and an input attachment was referenced by the <a href=\"#VkRenderPassInputAttachmentAspectCreateInfo\">VkRenderPassInputAttachmentAspectCreateInfo</a> at <code>renderPass</code> create time, its shader code <strong class=\"purple\">must</strong> not read from any aspect that was not specified in the <code>aspectMask</code> of the corresponding <a href=\"#VkInputAttachmentAspectReference\">VkInputAttachmentAspectReference</a> structure."\r
+ }\r
+ ],\r
+ "!(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-00755",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_DEPTH_BOUNDS</code>, and the <code>depthBoundsTestEnable</code> member of <code>pDepthStencilState</code> is <code>VK_TRUE</code>, the <code>minDepthBounds</code> and <code>maxDepthBounds</code> members of <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ],\r
+ "(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-00755",\r
+ "text": " If the <code><a href=\"#VK_EXT_depth_range_unrestricted\">VK_EXT_depth_range_unrestricted</a></code> extension is not enabled and no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_DEPTH_BOUNDS</code>, and the <code>depthBoundsTestEnable</code> member of <code>pDepthStencilState</code> is <code>VK_TRUE</code>, the <code>minDepthBounds</code> and <code>maxDepthBounds</code> members of <code>pDepthStencilState</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-01521",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT</code>, and the <code>sampleLocationsEnable</code> member of a <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a> structure chained to the <code>pNext</code> chain of <code>pMultisampleState</code> is <code>VK_TRUE</code>, <code>sampleLocationsInfo.sampleLocationGridSize.width</code> <strong class=\"purple\">must</strong> evenly divide <a href=\"#VkMultisamplePropertiesEXT\">VkMultisamplePropertiesEXT</a>::<code>sampleLocationGridSize.width</code> as returned by <a href=\"#vkGetPhysicalDeviceMultisamplePropertiesEXT\">vkGetPhysicalDeviceMultisamplePropertiesEXT</a> with a <code>samples</code> parameter equaling <code>rasterizationSamples</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-01522",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT</code>, and the <code>sampleLocationsEnable</code> member of a <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a> structure chained to the <code>pNext</code> chain of <code>pMultisampleState</code> is <code>VK_TRUE</code>, <code>sampleLocationsInfo.sampleLocationGridSize.height</code> <strong class=\"purple\">must</strong> evenly divide <a href=\"#VkMultisamplePropertiesEXT\">VkMultisamplePropertiesEXT</a>::<code>sampleLocationGridSize.height</code> as returned by <a href=\"#vkGetPhysicalDeviceMultisamplePropertiesEXT\">vkGetPhysicalDeviceMultisamplePropertiesEXT</a> with a <code>samples</code> parameter equaling <code>rasterizationSamples</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-01523",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT</code>, and the <code>sampleLocationsEnable</code> member of a <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a> structure chained to the <code>pNext</code> chain of <code>pMultisampleState</code> is <code>VK_TRUE</code>, <code>sampleLocationsInfo.sampleLocationsPerPixel</code> <strong class=\"purple\">must</strong> equal <code>rasterizationSamples</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-sampleLocationsEnable-01524",\r
+ "text": " If the <code>sampleLocationsEnable</code> member of a <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a> structure chained to the <code>pNext</code> chain of <code>pMultisampleState</code> is <code>VK_TRUE</code>, the fragment shader code <strong class=\"purple\">must</strong> not statically use the extended instruction <code>InterpolateAtSample</code>"\r
+ }\r
+ ],\r
+ "!(VK_AMD_mixed_attachment_samples)+!(VK_NV_framebuffer_mixed_samples)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-00757",\r
+ "text": " If <code>subpass</code> uses color and/or depth/stencil attachments, then the <code>rasterizationSamples</code> member of <code>pMultisampleState</code> <strong class=\"purple\">must</strong> be the same as the sample count for those subpass attachments"\r
+ }\r
+ ],\r
+ "(VK_AMD_mixed_attachment_samples)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-01505",\r
+ "text": " If <code>subpass</code> uses color and/or depth/stencil attachments, then the <code>rasterizationSamples</code> member of <code>pMultisampleState</code> <strong class=\"purple\">must</strong> equal the maximum of the sample counts of those subpass attachments"\r
+ }\r
+ ],\r
+ "(VK_NV_framebuffer_mixed_samples)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-01411",\r
+ "text": " If <code>subpass</code> has a depth/stencil attachment and depth test, stencil test, or depth bounds test are enabled, then the <code>rasterizationSamples</code> member of <code>pMultisampleState</code> <strong class=\"purple\">must</strong> be the same as the sample count of the depth/stencil attachment"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-subpass-01412",\r
+ "text": " If <code>subpass</code> has any color attachments, then the <code>rasterizationSamples</code> member of <code>pMultisampleState</code> <strong class=\"purple\">must</strong> be greater than or equal to the sample count for those subpass attachments"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-renderPass-00760",\r
+ "text": " If the <code>renderPass</code> has multiview enabled and <code>subpass</code> has more than one bit set in the view mask and <code>multiviewTessellationShader</code> is not enabled, then <code>pStages</code> <strong class=\"purple\">must</strong> not include tessellation shaders."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-renderPass-00761",\r
+ "text": " If the <code>renderPass</code> has multiview enabled and <code>subpass</code> has more than one bit set in the view mask and <code>multiviewGeometryShader</code> is not enabled, then <code>pStages</code> <strong class=\"purple\">must</strong> not include a geometry shader."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-renderPass-00762",\r
+ "text": " If the <code>renderPass</code> has multiview enabled and <code>subpass</code> has more than one bit set in the view mask, shaders in the pipeline <strong class=\"purple\">must</strong> not write to the <code>Layer</code> built-in output"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-renderPass-00763",\r
+ "text": " If the <code>renderPass</code> has multiview enabled, then all shaders <strong class=\"purple\">must</strong> not include variables decorated with the <code>Layer</code> built-in decoration in their interfaces."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-flags-00764",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not contain the <code>VK_PIPELINE_CREATE_DISPATCH_BASE</code> flag."\r
+ }\r
+ ],\r
+ "(VK_NV_clip_space_w_scaling)": [\r
+ {\r
+ "vuid": "VUID-VkGraphicsPipelineCreateInfo-pDynamicStates-01715",\r
+ "text": " If no element of the <code>pDynamicStates</code> member of <code>pDynamicState</code> is <code>VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV</code>, and the <code>viewportWScalingEnable</code> member of a <a href=\"#VkPipelineViewportWScalingStateCreateInfoNV\">VkPipelineViewportWScalingStateCreateInfoNV</a> structure, chained to the <code>pNext</code> chain of <code>pViewportState</code>, is <code>VK_TRUE</code>, the <code>pViewportWScalings</code> member of the <a href=\"#VkPipelineViewportWScalingStateCreateInfoNV\">VkPipelineViewportWScalingStateCreateInfoNV</a> <strong class=\"purple\">must</strong> be a pointer to an array of <a href=\"#VkPipelineViewportWScalingStateCreateInfoNV\">VkPipelineViewportWScalingStateCreateInfoNV</a>::<code>viewportCount</code> valid <a href=\"#VkViewportWScalingNV\">VkViewportWScalingNV</a> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineDynamicStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineDynamicStateCreateInfo-pDynamicStates-01442",\r
+ "text": " Each element of <code>pDynamicStates</code> <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDynamicStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDynamicStateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDynamicStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDynamicStateCreateInfo-pDynamicStates-parameter",\r
+ "text": " <code>pDynamicStates</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dynamicStateCount</code> valid <a href=\"#VkDynamicState\">VkDynamicState</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDynamicStateCreateInfo-dynamicStateCount-arraylength",\r
+ "text": " <code>dynamicStateCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyPipeline": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-pipeline-00765",\r
+ "text": " All submitted commands that refer to <code>pipeline</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-pipeline-00766",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>pipeline</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-pipeline-00767",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>pipeline</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-pipeline-parameter",\r
+ "text": " If <code>pipeline</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>pipeline</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipeline</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipeline-pipeline-parent",\r
+ "text": " If <code>pipeline</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreatePipelineCache": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineCache-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineCache-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineCacheCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineCache-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineCache-pPipelineCache-parameter",\r
+ "text": " <code>pPipelineCache</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPipelineCache</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineCacheCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineCacheCreateInfo-initialDataSize-00768",\r
+ "text": " If <code>initialDataSize</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be equal to the size of <code>pInitialData</code>, as returned by <code>vkGetPipelineCacheData</code> when <code>pInitialData</code> was originally retrieved"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCacheCreateInfo-initialDataSize-00769",\r
+ "text": " If <code>initialDataSize</code> is not <code>0</code>, <code>pInitialData</code> <strong class=\"purple\">must</strong> have been retrieved from a previous call to <code>vkGetPipelineCacheData</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCacheCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCacheCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCacheCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCacheCreateInfo-pInitialData-parameter",\r
+ "text": " If <code>initialDataSize</code> is not <code>0</code>, <code>pInitialData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>initialDataSize</code> bytes"\r
+ }\r
+ ]\r
+ },\r
+ "vkMergePipelineCaches": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-dstCache-00770",\r
+ "text": " <code>dstCache</code> <strong class=\"purple\">must</strong> not appear in the list of source caches"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-dstCache-parameter",\r
+ "text": " <code>dstCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineCache</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-pSrcCaches-parameter",\r
+ "text": " <code>pSrcCaches</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>srcCacheCount</code> valid <code>VkPipelineCache</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-srcCacheCount-arraylength",\r
+ "text": " <code>srcCacheCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-dstCache-parent",\r
+ "text": " <code>dstCache</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMergePipelineCaches-pSrcCaches-parent",\r
+ "text": " Each element of <code>pSrcCaches</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPipelineCacheData": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPipelineCacheData-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPipelineCacheData-pipelineCache-parameter",\r
+ "text": " <code>pipelineCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineCache</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPipelineCacheData-pDataSize-parameter",\r
+ "text": " <code>pDataSize</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>size_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPipelineCacheData-pData-parameter",\r
+ "text": " If the value referenced by <code>pDataSize</code> is not <code>0</code>, and <code>pData</code> is not <code>NULL</code>, <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pDataSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPipelineCacheData-pipelineCache-parent",\r
+ "text": " <code>pipelineCache</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyPipelineCache": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineCache-pipelineCache-00771",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>pipelineCache</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineCache-pipelineCache-00772",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>pipelineCache</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineCache-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineCache-pipelineCache-parameter",\r
+ "text": " If <code>pipelineCache</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>pipelineCache</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineCache</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineCache-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineCache-pipelineCache-parent",\r
+ "text": " If <code>pipelineCache</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSpecializationInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSpecializationInfo-offset-00773",\r
+ "text": " The <code>offset</code> member of each element of <code>pMapEntries</code> <strong class=\"purple\">must</strong> be less than <code>dataSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSpecializationInfo-pMapEntries-00774",\r
+ "text": " The <code>size</code> member of each element of <code>pMapEntries</code> <strong class=\"purple\">must</strong> be less than or equal to <code>dataSize</code> minus <code>offset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSpecializationInfo-mapEntryCount-00775",\r
+ "text": " If <code>mapEntryCount</code> is not <code>0</code>, <code>pMapEntries</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>mapEntryCount</code> valid <code>VkSpecializationMapEntry</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSpecializationInfo-pData-parameter",\r
+ "text": " If <code>dataSize</code> is not <code>0</code>, <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dataSize</code> bytes"\r
+ }\r
+ ]\r
+ },\r
+ "VkSpecializationMapEntry": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSpecializationMapEntry-constantID-00776",\r
+ "text": " For a <code>constantID</code> specialization constant declared in a shader, <code>size</code> <strong class=\"purple\">must</strong> match the byte size of the <code>constantID</code>. If the specialization constant is of type <code>boolean</code>, <code>size</code> <strong class=\"purple\">must</strong> be the byte size of <code>VkBool32</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBindPipeline": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipelineBindPoint-00777",\r
+ "text": " If <code>pipelineBindPoint</code> is <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipelineBindPoint-00778",\r
+ "text": " If <code>pipelineBindPoint</code> is <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipelineBindPoint-00779",\r
+ "text": " If <code>pipelineBindPoint</code> is <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, <code>pipeline</code> <strong class=\"purple\">must</strong> be a compute pipeline"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipelineBindPoint-00780",\r
+ "text": " If <code>pipelineBindPoint</code> is <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, <code>pipeline</code> <strong class=\"purple\">must</strong> be a graphics pipeline"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipeline-00781",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-variableMultisampleRate,variable multisample rate&amp;gt;&amp;gt; feature is not supported, <code>pipeline</code> is a graphics pipeline, the current subpass has no attachments, and this is not the first call to this function with a graphics pipeline after transitioning to the current subpass, then the sample count specified by this pipeline <strong class=\"purple\">must</strong> match that set in the previous pipeline"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipelineBindPoint-parameter",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineBindPoint\">VkPipelineBindPoint</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-pipeline-parameter",\r
+ "text": " <code>pipeline</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipeline</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>pipeline</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBindPipeline-variableSampleLocations-01525",\r
+ "text": " If <a href=\"#VkPhysicalDeviceSampleLocationsPropertiesEXT\">VkPhysicalDeviceSampleLocationsPropertiesEXT</a>::<code>variableSampleLocations</code> is <code>VK_FALSE</code>, and <code>pipeline</code> is a graphics pipeline created with a <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a> structure having its <code>sampleLocationsEnable</code> member set to <code>VK_TRUE</code> but without <code>VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT</code> enabled then the current render pass instance <strong class=\"purple\">must</strong> have been begun by specifying a <a href=\"#VkRenderPassSampleLocationsBeginInfoEXT\">VkRenderPassSampleLocationsBeginInfoEXT</a> structure whose <code>pPostSubpassSampleLocations</code> member contains an element with a <code>subpassIndex</code> matching the current subpass index and the <code>sampleLocationsInfo</code> member of that element <strong class=\"purple\">must</strong> match the <code>sampleLocationsInfo</code> specified in <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a> when the pipeline was created"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetShaderInfoAMD": {\r
+ "(VK_AMD_shader_info)": [\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-pipeline-parameter",\r
+ "text": " <code>pipeline</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipeline</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-shaderStage-parameter",\r
+ "text": " <code>shaderStage</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkShaderStageFlagBits\">VkShaderStageFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-infoType-parameter",\r
+ "text": " <code>infoType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkShaderInfoTypeAMD\">VkShaderInfoTypeAMD</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-pInfoSize-parameter",\r
+ "text": " <code>pInfoSize</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>size_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-pInfo-parameter",\r
+ "text": " If the value referenced by <code>pInfoSize</code> is not <code>0</code>, and <code>pInfo</code> is not <code>NULL</code>, <code>pInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pInfoSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetShaderInfoAMD-pipeline-parent",\r
+ "text": " <code>pipeline</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkAllocationCallbacks": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkAllocationCallbacks-pfnAllocation-00632",\r
+ "text": " <code>pfnAllocation</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid user-defined <a href=\"#PFN_vkAllocationFunction\">PFN_vkAllocationFunction</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAllocationCallbacks-pfnReallocation-00633",\r
+ "text": " <code>pfnReallocation</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid user-defined <a href=\"#PFN_vkReallocationFunction\">PFN_vkReallocationFunction</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAllocationCallbacks-pfnFree-00634",\r
+ "text": " <code>pfnFree</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid user-defined <a href=\"#PFN_vkFreeFunction\">PFN_vkFreeFunction</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAllocationCallbacks-pfnInternalAllocation-00635",\r
+ "text": " If either of <code>pfnInternalAllocation</code> or <code>pfnInternalFree</code> is not <code>NULL</code>, both <strong class=\"purple\">must</strong> be valid callbacks"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceMemoryProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMemoryProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMemoryProperties-pMemoryProperties-parameter",\r
+ "text": " <code>pMemoryProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPhysicalDeviceMemoryProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceMemoryProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMemoryProperties2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMemoryProperties2-pMemoryProperties-parameter",\r
+ "text": " <code>pMemoryProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPhysicalDeviceMemoryProperties2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceMemoryProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMemoryProperties2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMemoryProperties2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkAllocateMemory": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkAllocateMemory-pAllocateInfo-01713",\r
+ "text": " <code>pAllocateInfo</code>\\-&amp;gt;<code>allocationSize</code> <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMemoryProperties\">VkPhysicalDeviceMemoryProperties</a>::<code>memoryHeaps</code>[<code>pAllocateInfo</code>\\-&amp;gt;<code>memoryTypeIndex</code>].<code>size</code> as returned by <a href=\"#vkGetPhysicalDeviceMemoryProperties\">vkGetPhysicalDeviceMemoryProperties</a> for the <a href=\"#VkPhysicalDevice\">VkPhysicalDevice</a> that <code>device</code> was created from."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateMemory-pAllocateInfo-01714",\r
+ "text": " <code>pAllocateInfo</code>\\-&amp;gt;<code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> be less than <a href=\"#VkPhysicalDeviceMemoryProperties\">VkPhysicalDeviceMemoryProperties</a>::<code>memoryTypeCount</code> as returned by <a href=\"#vkGetPhysicalDeviceMemoryProperties\">vkGetPhysicalDeviceMemoryProperties</a> for the <a href=\"#VkPhysicalDevice\">VkPhysicalDevice</a> that <code>device</code> was created from."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateMemory-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateMemory-pAllocateInfo-parameter",\r
+ "text": " <code>pAllocateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkMemoryAllocateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateMemory-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateMemory-pMemory-parameter",\r
+ "text": " <code>pMemory</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDeviceMemory</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryAllocateInfo": {\r
+ "!(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-allocationSize-00638",\r
+ "text": " <code>allocationSize</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_external_memory)+(VK_KHR_dedicated_allocation,VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-pNext-00639",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <code>VkExportMemoryAllocateInfo</code>, and any of the handle types specified in <code>VkExportMemoryAllocateInfo</code>::<code>handleTypes</code> require a dedicated allocation, as reported by <a href=\"#vkGetPhysicalDeviceImageFormatProperties2\">vkGetPhysicalDeviceImageFormatProperties2</a> in <code>VkExternalImageFormatProperties</code>::<code>externalMemoryProperties</code>::<code>externalMemoryFeatures</code> or <code>VkExternalBufferProperties</code>::<code>externalMemoryProperties</code>::<code>externalMemoryFeatures</code>, the <code>pNext</code> chain must contain an instance of ifdef::VK_KHR_dedicated_allocation[<a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>]"\r
+ }\r
+ ],\r
+ "(VK_KHR_external_memory)+(VK_NV_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-pNext-00640",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkExportMemoryAllocateInfo\">VkExportMemoryAllocateInfo</a>, it <strong class=\"purple\">must</strong> not contain an instance of <a href=\"#VkExportMemoryAllocateInfoNV\">VkExportMemoryAllocateInfoNV</a> or <a href=\"#VkExportMemoryWin32HandleInfoNV\">VkExportMemoryWin32HandleInfoNV</a>."\r
+ }\r
+ ],\r
+ "(VK_KHR_external_memory_win32+VK_NV_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-pNext-00641",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkImportMemoryWin32HandleInfoKHR\">VkImportMemoryWin32HandleInfoKHR</a>, it <strong class=\"purple\">must</strong> not contain an instance of <a href=\"#VkImportMemoryWin32HandleInfoNV\">VkImportMemoryWin32HandleInfoNV</a>."\r
+ }\r
+ ],\r
+ "(VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-allocationSize-01742",\r
+ "text": " If the parameters define an import operation, the external handle specified was created by the Vulkan API, and the external handle type is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR</code>, then the values of <code>allocationSize</code> and <code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> match those specified when the memory object being imported was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-memoryTypeIndex-00648",\r
+ "text": " If the parameters define an import operation and the external handle is a POSIX file descriptor created outside of the Vulkan API, the value of <code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> be one of those returned by <a href=\"#vkGetMemoryFdPropertiesKHR\">vkGetMemoryFdPropertiesKHR</a>."\r
+ }\r
+ ],\r
+ "(VK_KHR_external_memory+VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-None-00643",\r
+ "text": " If the parameters define an import operation and the external handle specified was created by the Vulkan API, the device mask specified by <a href=\"#VkMemoryAllocateFlagsInfo\">VkMemoryAllocateFlagsInfo</a> <strong class=\"purple\">must</strong> match that specified when the memory object being imported was allocated."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-None-00644",\r
+ "text": " If the parameters define an import operation and the external handle specified was created by the Vulkan API, the list of physical devices that comprise the logical device passed to <a href=\"#vkAllocateMemory\">vkAllocateMemory</a> <strong class=\"purple\">must</strong> match the list of physical devices that comprise the logical device on which the memory was originally allocated."\r
+ }\r
+ ],\r
+ "(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-memoryTypeIndex-00645",\r
+ "text": " If the parameters define an import operation and the external handle is an NT handle or a global share handle created outside of the Vulkan API, the value of <code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> be one of those returned by <a href=\"#vkGetMemoryWin32HandlePropertiesKHR\">vkGetMemoryWin32HandlePropertiesKHR</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-allocationSize-01743",\r
+ "text": " If the parameters define an import operation, the external handle was created by the Vulkan API, and the external handle type is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR</code> or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR</code>, then the values of <code>allocationSize</code> and <code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> match those specified when the memory object being imported was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-allocationSize-00646",\r
+ "text": " If the parameters define an import operation and the external handle type is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT</code>, or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT</code>, <code>allocationSize</code> <strong class=\"purple\">must</strong> match the size reported in the memory requirements of the <code>image</code> or <code>buffer</code> member of the instance of <code>VkDedicatedAllocationMemoryAllocateInfoNV</code> included in the <code>pNext</code> chain."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-allocationSize-00647",\r
+ "text": " If the parameters define an import operation and the external handle type is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT</code>, <code>allocationSize</code> <strong class=\"purple\">must</strong> match the size specified when creating the Direct3D 12 heap from which the external handle was extracted."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-memoryTypeIndex-01872",\r
+ "text": " If the protected memory feature is not enabled, the <code>VkMemoryAllocateInfo</code>::<code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> not indicate a memory type that reports <code>VK_MEMORY_PROPERTY_PROTECTED_BIT</code>."\r
+ }\r
+ ],\r
+ "(VK_EXT_external_memory_host)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-memoryTypeIndex-01744",\r
+ "text": " If the parameters define an import operation and the external handle is a host pointer, the value of <code>memoryTypeIndex</code> <strong class=\"purple\">must</strong> be one of those returned by <a href=\"#vkGetMemoryHostPointerPropertiesEXT\">vkGetMemoryHostPointerPropertiesEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-allocationSize-01745",\r
+ "text": " If the parameters define an import operation and the external handle is a host pointer, <code>allocationSize</code> <strong class=\"purple\">must</strong> be an integer multiple of <code>VkPhysicalDeviceExternalMemoryHostPropertiesEXT</code>::<code>minImportedHostPointerAlignment</code>"\r
+ }\r
+ ],\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-None-01873",\r
+ "text": " If the parameters define an import operation and the external handle type is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BIT_ANDROID</code>:"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-pNext-01874",\r
+ "text": " If the parameters do not define an import operation, and the <code>pNext</code> chain contains an instance of <code>VkExportMemoryAllocateInfo</code> with <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID</code> included in its <code>handleTypes</code> member, and the <code>pNext</code> contains an instance of <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a> with <code>image</code> not equal to <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, then <code>allocationSize</code> <strong class=\"purple\">must</strong> be <code>0</code>, otherwise <code>allocationSize</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-pNext-01875",\r
+ "text": " If the parameters define an import operation, the external handle is an Android hardware buffer, and the <code>pNext</code> chain includes an instance of <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a> with <code>image</code> that is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>:"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDedicatedAllocationMemoryAllocateInfoNV\">VkDedicatedAllocationMemoryAllocateInfoNV</a>, <a href=\"#VkExportMemoryAllocateInfo\">VkExportMemoryAllocateInfo</a>, <a href=\"#VkExportMemoryAllocateInfoNV\">VkExportMemoryAllocateInfoNV</a>, <a href=\"#VkExportMemoryWin32HandleInfoKHR\">VkExportMemoryWin32HandleInfoKHR</a>, <a href=\"#VkExportMemoryWin32HandleInfoNV\">VkExportMemoryWin32HandleInfoNV</a>, <a href=\"#VkImportAndroidHardwareBufferInfoANDROID\">VkImportAndroidHardwareBufferInfoANDROID</a>, <a href=\"#VkImportMemoryFdInfoKHR\">VkImportMemoryFdInfoKHR</a>, <a href=\"#VkImportMemoryHostPointerInfoEXT\">VkImportMemoryHostPointerInfoEXT</a>, <a href=\"#VkImportMemoryWin32HandleInfoKHR\">VkImportMemoryWin32HandleInfoKHR</a>, <a href=\"#VkImportMemoryWin32HandleInfoNV\">VkImportMemoryWin32HandleInfoNV</a>, <a href=\"#VkMemoryAllocateFlagsInfo\">VkMemoryAllocateFlagsInfo</a>, or <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryDedicatedAllocateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-01432",\r
+ "text": " At least one of <code>image</code> and <code>buffer</code> <strong class=\"purple\">must</strong> be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-01433",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>VkMemoryAllocateInfo</code>::<code>allocationSize</code> <strong class=\"purple\">must</strong> equal the <code>VkMemoryRequirements</code>::<code>size</code> of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-01434",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>image</code> <strong class=\"purple\">must</strong> have been created without <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code> set in <code>VkImageCreateInfo</code>::<code>flags</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-buffer-01435",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>VkMemoryAllocateInfo</code>::<code>allocationSize</code> <strong class=\"purple\">must</strong> equal the <code>VkMemoryRequirements</code>::<code>size</code> of the buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-buffer-01436",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>buffer</code> <strong class=\"purple\">must</strong> have been created without <code>VK_BUFFER_CREATE_SPARSE_BINDING_BIT</code> set in <a href=\"#VkBufferCreateInfo\">VkBufferCreateInfo</a>::<code>flags</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-parameter",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-buffer-parameter",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>image</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)+(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-01876",\r
+ "text": " If <code>image</code> is not <code>VK_NULL_HANDLE</code> and <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a> defines a memory import operation with handle type <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT</code>, or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT</code>, and the external handle was created by the Vulkan API, then the memory being imported <strong class=\"purple\">must</strong> also be a dedicated image allocation and <code>image</code> must be identical to the image associated with the imported memory."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-buffer-01877",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> and <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a> defines a memory import operation with handle type <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT</code>, or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT</code>, and the external handle was created by the Vulkan API, then the memory being imported <strong class=\"purple\">must</strong> also be a dedicated buffer allocation and <code>buffer</code> must be identical to the buffer associated with the imported memory."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)+(VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-01878",\r
+ "text": " If <code>image</code> is not <code>VK_NULL_HANDLE</code> and <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a> defines a memory import operation with handle type <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT</code>, the memory being imported <strong class=\"purple\">must</strong> also be a dedicated image allocation and <code>image</code> must be identical to the image associated with the imported memory."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-buffer-01879",\r
+ "text": " If <code>buffer</code> is not <code>VK_NULL_HANDLE</code> and <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a> defines a memory import operation with handle type <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT</code>, the memory being imported <strong class=\"purple\">must</strong> also be a dedicated buffer allocation and <code>buffer</code> must be identical to the buffer associated with the imported memory."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)+(VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedAllocateInfo-image-01797",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>image</code> <strong class=\"purple\">must</strong> not have been created with <code>VK_IMAGE_CREATE_DISJOINT_BIT</code> set in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a>::<code>flags</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDedicatedAllocationMemoryAllocateInfoNV": {\r
+ "(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-image-00649",\r
+ "text": " At least one of <code>image</code> and <code>buffer</code> <strong class=\"purple\">must</strong> be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-image-00650",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, the image <strong class=\"purple\">must</strong> have been created with <code>VkDedicatedAllocationImageCreateInfoNV</code>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-buffer-00651",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, the buffer <strong class=\"purple\">must</strong> have been created with <code>VkDedicatedAllocationBufferCreateInfoNV</code>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-image-00652",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>VkMemoryAllocateInfo</code>::<code>allocationSize</code> <strong class=\"purple\">must</strong> equal the <code>VkMemoryRequirements</code>::<code>size</code> of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-buffer-00653",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>VkMemoryAllocateInfo</code>::<code>allocationSize</code> <strong class=\"purple\">must</strong> equal the <code>VkMemoryRequirements</code>::<code>size</code> of the buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-image-parameter",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-buffer-parameter",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>image</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_NV_dedicated_allocation)+(VK_KHR_external_memory_win32,VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-image-00654",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> and <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a> defines a memory import operation, the memory being imported <strong class=\"purple\">must</strong> also be a dedicated image allocation and <code>image</code> <strong class=\"purple\">must</strong> be identical to the image associated with the imported memory."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationMemoryAllocateInfoNV-buffer-00655",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> and <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a> defines a memory import operation, the memory being imported <strong class=\"purple\">must</strong> also be a dedicated buffer allocation and <code>buffer</code> <strong class=\"purple\">must</strong> be identical to the buffer associated with the imported memory."\r
+ }\r
+ ]\r
+ },\r
+ "VkExportMemoryAllocateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkExportMemoryAllocateInfo-handleTypes-00656",\r
+ "text": " The bits in <code>handleTypes</code> <strong class=\"purple\">must</strong> be supported and compatible, as reported by <a href=\"#VkExternalImageFormatProperties\">VkExternalImageFormatProperties</a> or <a href=\"#VkExternalBufferProperties\">VkExternalBufferProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportMemoryAllocateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportMemoryAllocateInfo-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportMemoryWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkExportMemoryWin32HandleInfoKHR-handleTypes-00657",\r
+ "text": " If <a href=\"#VkExportMemoryAllocateInfo\">VkExportMemoryAllocateInfo</a>::<code>handleTypes</code> does not include <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT</code>, or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT</code>, VkExportMemoryWin32HandleInfoKHR <strong class=\"purple\">must</strong> not be in the <code>pNext</code> chain of <a href=\"#VkMemoryAllocateInfo\">VkMemoryAllocateInfo</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportMemoryWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportMemoryWin32HandleInfoKHR-pAttributes-parameter",\r
+ "text": " If <code>pAttributes</code> is not <code>NULL</code>, <code>pAttributes</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>SECURITY_ATTRIBUTES</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportMemoryWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handleType-00658",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be supported for import, as reported by <a href=\"#VkExternalImageFormatProperties\">VkExternalImageFormatProperties</a> or <a href=\"#VkExternalBufferProperties\">VkExternalBufferProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handle-00659",\r
+ "text": " The memory from which <code>handle</code> was exported, or the memory named by <code>name</code> <strong class=\"purple\">must</strong> have been created on the same underlying physical device as <code>device</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handleType-00660",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be defined as an NT handle or a global share handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handleType-01439",\r
+ "text": " If <code>handleType</code> is not <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT</code>, <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT</code>, or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT</code>, <code>name</code> <strong class=\"purple\">must</strong> be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handleType-01440",\r
+ "text": " If <code>handleType</code> is not <code>0</code> and <code>handle</code> is <code>NULL</code>, <code>name</code> <strong class=\"purple\">must</strong> name a valid memory resource of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handleType-00661",\r
+ "text": " If <code>handleType</code> is not <code>0</code> and <code>name</code> is <code>NULL</code>, <code>handle</code> <strong class=\"purple\">must</strong> be a valid handle of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handle-01441",\r
+ "text": " if <code>handle</code> is not <code>NULL</code>, <code>name</code> must be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handle-01518",\r
+ "text": " If <code>handle</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in <a href=\"#external-memory-handle-types-compatibility\">external memory handle types compatibility</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-name-01519",\r
+ "text": " If <code>name</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in <a href=\"#external-memory-handle-types-compatibility\">external memory handle types compatibility</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoKHR-handleType-parameter",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryWin32HandleKHR": {\r
+ "(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleKHR-pGetWin32HandleInfo-parameter",\r
+ "text": " <code>pGetWin32HandleInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkMemoryGetWin32HandleInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleKHR-pHandle-parameter",\r
+ "text": " <code>pHandle</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>HANDLE</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryGetWin32HandleInfoKHR": {\r
+ "(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-handleType-00662",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportMemoryAllocateInfo\">VkExportMemoryAllocateInfo</a>::<code>handleTypes</code> when <code>memory</code> was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-handleType-00663",\r
+ "text": " If <code>handleType</code> is defined as an NT handle, <a href=\"#vkGetMemoryWin32HandleKHR\">vkGetMemoryWin32HandleKHR</a> <strong class=\"purple\">must</strong> be called no more than once for each valid unique combination of <code>memory</code> and <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-handleType-00664",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be defined as an NT handle or a global share handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_GET_WIN32_HANDLE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetWin32HandleInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryWin32HandlePropertiesKHR": {\r
+ "(VK_KHR_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandlePropertiesKHR-handle-00665",\r
+ "text": " <code>handle</code> <strong class=\"purple\">must</strong> be an external memory handle created outside of the Vulkan API."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandlePropertiesKHR-handleType-00666",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> not be one of the handle types defined as opaque."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandlePropertiesKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandlePropertiesKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandlePropertiesKHR-pMemoryWin32HandleProperties-parameter",\r
+ "text": " <code>pMemoryWin32HandleProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryWin32HandlePropertiesKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportMemoryFdInfoKHR": {\r
+ "(VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-handleType-00667",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be supported for import, as reported by <a href=\"#VkExternalImageFormatProperties\">VkExternalImageFormatProperties</a> or <a href=\"#VkExternalBufferProperties\">VkExternalBufferProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-fd-00668",\r
+ "text": " The memory from which <code>fd</code> was exported <strong class=\"purple\">must</strong> have been created on the same underlying physical device as <code>device</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-handleType-00669",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be defined as a POSIX file descriptor handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-handleType-00670",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, <code>fd</code> <strong class=\"purple\">must</strong> be a valid handle of the type specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-fd-01746",\r
+ "text": " The memory represented by <code>fd</code> <strong class=\"purple\">must</strong> have been created from a physical device and driver that is compatible with <code>device</code> and <code>handleType</code>, as described in &amp;lt;&amp;lt;external-memory-handle-types-compatibility&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-fd-01520",\r
+ "text": " <code>fd</code> <strong class=\"purple\">must</strong> obey any requirements listed for <code>handleType</code> in &amp;lt;&amp;lt;external-memory-handle-types-compatibility,external memory handle types compatibility&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryFdInfoKHR-handleType-parameter",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryFdKHR": {\r
+ "(VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdKHR-pGetFdInfo-parameter",\r
+ "text": " <code>pGetFdInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkMemoryGetFdInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdKHR-pFd-parameter",\r
+ "text": " <code>pFd</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>int</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryGetFdInfoKHR": {\r
+ "(VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryGetFdInfoKHR-handleType-00671",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportMemoryAllocateInfo\">VkExportMemoryAllocateInfo</a>::<code>handleTypes</code> when <code>memory</code> was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetFdInfoKHR-handleType-00672",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be defined as a POSIX file descriptor handle."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetFdInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetFdInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetFdInfoKHR-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetFdInfoKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryFdPropertiesKHR": {\r
+ "(VK_KHR_external_memory_fd)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdPropertiesKHR-fd-00673",\r
+ "text": " <code>fd</code> <strong class=\"purple\">must</strong> be an external memory handle created outside of the Vulkan API."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdPropertiesKHR-handleType-00674",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> not be <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdPropertiesKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdPropertiesKHR-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryFdPropertiesKHR-pMemoryFdProperties-parameter",\r
+ "text": " <code>pMemoryFdProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryFdPropertiesKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportMemoryHostPointerInfoEXT": {\r
+ "(VK_EXT_external_memory_host)": [\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-handleType-01747",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be supported for import, as reported in <a href=\"#VkExternalMemoryPropertiesKHR\">VkExternalMemoryPropertiesKHR</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-handleType-01748",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, it <strong class=\"purple\">must</strong> be <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT</code> or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-pHostPointer-01749",\r
+ "text": " <code>pHostPointer</code> <strong class=\"purple\">must</strong> be a pointer aligned to an integer multiple of <code>VkPhysicalDeviceExternalMemoryHostPropertiesEXT</code>::<code>minImportedHostPointerAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-handleType-01750",\r
+ "text": " If <code>handleType</code> is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT</code>, <code>pHostPointer</code> <strong class=\"purple\">must</strong> be a pointer to <code>allocationSize</code> number of bytes of host memory, where <code>allocationSize</code> is the member of the <code>VkMemoryAllocateInfo</code> structure this structure is chained to"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-handleType-01751",\r
+ "text": " If <code>handleType</code> is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT</code>, <code>pHostPointer</code> <strong class=\"purple\">must</strong> be a pointer to <code>allocationSize</code> number of bytes of host mapped foreign memory, where <code>allocationSize</code> is the member of the <code>VkMemoryAllocateInfo</code> structure this structure is chained to"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryHostPointerInfoEXT-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryHostPointerPropertiesEXT": {\r
+ "(VK_EXT_external_memory_host)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-handleType-01752",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT</code> or <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-pHostPointer-01753",\r
+ "text": " <code>pHostPointer</code> <strong class=\"purple\">must</strong> be a pointer aligned to an integer multiple of <code>VkPhysicalDeviceExternalMemoryHostPropertiesEXT</code>::<code>minImportedHostPointerAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-handleType-01754",\r
+ "text": " If <code>handleType</code> is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT</code>, <code>pHostPointer</code> <strong class=\"purple\">must</strong> be a pointer to host memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-handleType-01755",\r
+ "text": " If <code>handleType</code> is <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT</code>, <code>pHostPointer</code> <strong class=\"purple\">must</strong> be a pointer to host mapped foreign memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryHostPointerPropertiesEXT-pMemoryHostPointerProperties-parameter",\r
+ "text": " <code>pMemoryHostPointerProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryHostPointerPropertiesEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryHostPointerPropertiesEXT": {\r
+ "(VK_EXT_external_memory_host)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryHostPointerPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryHostPointerPropertiesEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportAndroidHardwareBufferInfoANDROID": {\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkImportAndroidHardwareBufferInfoANDROID-buffer-01880",\r
+ "text": " If <code>buffer</code> is not <code>NULL</code>, Android hardware buffers <strong class=\"purple\">must</strong> be supported for import, as reported by <a href=\"#VkExternalImageFormatProperties\">VkExternalImageFormatProperties</a> or <a href=\"#VkExternalBufferProperties\">VkExternalBufferProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportAndroidHardwareBufferInfoANDROID-buffer-01881",\r
+ "text": " If <code>buffer</code> is not <code>NULL</code>, it <strong class=\"purple\">must</strong> be a valid Android hardware buffer object with format and usage compatible with Vulkan as described by <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportAndroidHardwareBufferInfoANDROID-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_ANDROID_HARDWARE_BUFFER_INFO_ANDROID</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportAndroidHardwareBufferInfoANDROID-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>AHardwareBuffer</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryAndroidHardwareBufferANDROID": {\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryAndroidHardwareBufferANDROID-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryAndroidHardwareBufferANDROID-pInfo-parameter",\r
+ "text": " <code>pInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkMemoryGetAndroidHardwareBufferInfoANDROID</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryAndroidHardwareBufferANDROID-pBuffer-parameter",\r
+ "text": " <code>pBuffer</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid pointer to a <code>AHardwareBuffer</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryGetAndroidHardwareBufferInfoANDROID": {\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryGetAndroidHardwareBufferInfoANDROID-handleTypes-01882",\r
+ "text": " <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID</code> <strong class=\"purple\">must</strong> have been included in <a href=\"#VkExportMemoryAllocateInfoKHR\">VkExportMemoryAllocateInfoKHR</a>::<code>handleTypes</code> when <code>memory</code> was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryGetAndroidHardwareBufferInfoANDROID-pNext-01883",\r
+ "text": " If the <code>pNext</code> chain of the <code>VkMemoryAllocateInfo</code> used to allocate <code>memory</code> included a <code>VkMemoryDedicatedAllocateInfo</code> with non-NULL <code>image</code> member, then that <code>image</code> <strong class=\"purple\">must</strong> already be bound to <code>memory</code>."\r
+ }\r
+ ]\r
+ },\r
+ "vkGetAndroidHardwareBufferPropertiesANDROID": {\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-vkGetAndroidHardwareBufferPropertiesANDROID-buffer-01884",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid Android hardware buffer object with at least one of the <code>AHARDWAREBUFFER_USAGE_GPU_</code>* usage flags."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetAndroidHardwareBufferPropertiesANDROID-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetAndroidHardwareBufferPropertiesANDROID-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>AHardwareBuffer</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetAndroidHardwareBufferPropertiesANDROID-pProperties-parameter",\r
+ "text": " <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkAndroidHardwareBufferPropertiesANDROID</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkAndroidHardwareBufferFormatPropertiesANDROID": {\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkAndroidHardwareBufferFormatPropertiesANDROID-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_FORMAT_PROPERTIES_ANDROID</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportMemoryAllocateInfoNV": {\r
+ "(VK_NV_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkExportMemoryAllocateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportMemoryAllocateInfoNV-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBitsNV\">VkExternalMemoryHandleTypeFlagBitsNV</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkExportMemoryWin32HandleInfoNV": {\r
+ "(VK_NV_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkExportMemoryWin32HandleInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExportMemoryWin32HandleInfoNV-pAttributes-parameter",\r
+ "text": " If <code>pAttributes</code> is not <code>NULL</code>, <code>pAttributes</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>SECURITY_ATTRIBUTES</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkImportMemoryWin32HandleInfoNV": {\r
+ "(VK_NV_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoNV-handleType-01327",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> not have more than one bit set."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoNV-handle-01328",\r
+ "text": " <code>handle</code> <strong class=\"purple\">must</strong> be a valid handle to memory, obtained as specified by <code>handleType</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImportMemoryWin32HandleInfoNV-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBitsNV\">VkExternalMemoryHandleTypeFlagBitsNV</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetMemoryWin32HandleNV": {\r
+ "(VK_NV_external_memory_win32)": [\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-handleType-01326",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a flag specified in <a href=\"#VkExportMemoryAllocateInfoNV\">VkExportMemoryAllocateInfoNV</a>::<code>handleTypes</code> when allocating <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBitsNV\">VkExternalMemoryHandleTypeFlagBitsNV</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-handleType-requiredbitmask",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-pHandle-parameter",\r
+ "text": " <code>pHandle</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>HANDLE</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetMemoryWin32HandleNV-memory-parent",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryAllocateFlagsInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateFlagsInfo-deviceMask-00675",\r
+ "text": " If <code>VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT</code> is set, <code>deviceMask</code> <strong class=\"purple\">must</strong> be a valid device mask."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateFlagsInfo-deviceMask-00676",\r
+ "text": " If <code>VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT</code> is set, <code>deviceMask</code> <strong class=\"purple\">must</strong> not be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateFlagsInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryAllocateFlagsInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkMemoryAllocateFlagBits\">VkMemoryAllocateFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkFreeMemory": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkFreeMemory-memory-00677",\r
+ "text": " All submitted commands that refer to <code>memory</code> (via images or buffers) <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeMemory-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeMemory-memory-parameter",\r
+ "text": " If <code>memory</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeMemory-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeMemory-memory-parent",\r
+ "text": " If <code>memory</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkMapMemory": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkMapMemory-memory-00678",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> not be currently mapped"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-offset-00679",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than the size of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-size-00680",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-size-00681",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to the size of the <code>memory</code> minus <code>offset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-memory-00682",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created with a memory type that reports <code>VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-ppData-parameter",\r
+ "text": " <code>ppData</code> <strong class=\"purple\">must</strong> be a valid pointer to a pointer value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkMapMemory-memory-parent",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkMapMemory-memory-00683",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> not have been allocated with multiple instances."\r
+ }\r
+ ]\r
+ },\r
+ "vkFlushMappedMemoryRanges": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkFlushMappedMemoryRanges-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFlushMappedMemoryRanges-pMemoryRanges-parameter",\r
+ "text": " <code>pMemoryRanges</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>memoryRangeCount</code> valid <code>VkMappedMemoryRange</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFlushMappedMemoryRanges-memoryRangeCount-arraylength",\r
+ "text": " <code>memoryRangeCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkInvalidateMappedMemoryRanges": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkInvalidateMappedMemoryRanges-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkInvalidateMappedMemoryRanges-pMemoryRanges-parameter",\r
+ "text": " <code>pMemoryRanges</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>memoryRangeCount</code> valid <code>VkMappedMemoryRange</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkInvalidateMappedMemoryRanges-memoryRangeCount-arraylength",\r
+ "text": " <code>memoryRangeCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkMappedMemoryRange": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-memory-00684",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be currently mapped"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-size-00685",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>offset</code> and <code>size</code> <strong class=\"purple\">must</strong> specify a range contained within the currently mapped range of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-size-00686",\r
+ "text": " If <code>size</code> is equal to <code>VK_WHOLE_SIZE</code>, <code>offset</code> <strong class=\"purple\">must</strong> be within the currently mapped range of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-size-01389",\r
+ "text": " If <code>size</code> is equal to <code>VK_WHOLE_SIZE</code>, the end of the current mapping of <code>memory</code> <strong class=\"purple\">must</strong> be a multiple of <a href=\"#VkPhysicalDeviceLimits\">VkPhysicalDeviceLimits</a>::<code>nonCoherentAtomSize</code> bytes from the beginning of the memory object."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-offset-00687",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <a href=\"#VkPhysicalDeviceLimits\">VkPhysicalDeviceLimits</a>::<code>nonCoherentAtomSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-size-01390",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> either be a multiple of <a href=\"#VkPhysicalDeviceLimits\">VkPhysicalDeviceLimits</a>::<code>nonCoherentAtomSize</code>, or <code>offset</code> plus <code>size</code> <strong class=\"purple\">must</strong> equal the size of <code>memory</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMappedMemoryRange-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkUnmapMemory": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkUnmapMemory-memory-00689",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be currently mapped"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnmapMemory-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnmapMemory-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnmapMemory-memory-parent",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceMemoryCommitment": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceMemoryCommitment-memory-00690",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created with a memory type that reports <code>VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceMemoryCommitment-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceMemoryCommitment-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceMemoryCommitment-pCommittedMemoryInBytes-parameter",\r
+ "text": " <code>pCommittedMemoryInBytes</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDeviceSize</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceMemoryCommitment-memory-parent",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceGroupPeerMemoryFeatures": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-heapIndex-00691",\r
+ "text": " <code>heapIndex</code> <strong class=\"purple\">must</strong> be less than <code>memoryHeapCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-localDeviceIndex-00692",\r
+ "text": " <code>localDeviceIndex</code> <strong class=\"purple\">must</strong> be a valid device index"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-remoteDeviceIndex-00693",\r
+ "text": " <code>remoteDeviceIndex</code> <strong class=\"purple\">must</strong> be a valid device index"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-localDeviceIndex-00694",\r
+ "text": " <code>localDeviceIndex</code> <strong class=\"purple\">must</strong> not equal remoteDeviceIndex"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-pPeerMemoryFeatures-parameter",\r
+ "text": " <code>pPeerMemoryFeatures</code> <strong class=\"purple\">must</strong> be a valid pointer to a <a href=\"#VkPeerMemoryFeatureFlags\">VkPeerMemoryFeatureFlags</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPeerMemoryFeatures-pPeerMemoryFeatures-requiredbitmask",\r
+ "text": " <code>pPeerMemoryFeatures</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateBuffer-flags-00911",\r
+ "text": " If the <code>flags</code> member of <code>pCreateInfo</code> includes <code>VK_BUFFER_CREATE_SPARSE_BINDING_BIT</code>, creating this <code>VkBuffer</code> <strong class=\"purple\">must</strong> not cause the total required sparse memory for all currently valid sparse resources on the device to exceed <code>VkPhysicalDeviceLimits</code>::<code>sparseAddressSpaceSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBuffer-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBuffer-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkBufferCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBuffer-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBuffer-pBuffer-parameter",\r
+ "text": " <code>pBuffer</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkBuffer</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkBufferCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-size-00912",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sharingMode-00913",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>queueFamilyIndexCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sharingMode-00914",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, <code>queueFamilyIndexCount</code> <strong class=\"purple\">must</strong> be greater than <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-flags-00915",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseBinding,sparse bindings&amp;gt;&amp;gt; feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_BUFFER_CREATE_SPARSE_BINDING_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-flags-00916",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidencyBuffer,sparse buffer residency&amp;gt;&amp;gt; feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-flags-00917",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidencyAliased,sparse aliased residency&amp;gt;&amp;gt; feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_BUFFER_CREATE_SPARSE_ALIASED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-flags-00918",\r
+ "text": " If <code>flags</code> contains <code>VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT</code> or <code>VK_BUFFER_CREATE_SPARSE_ALIASED_BIT</code>, it <strong class=\"purple\">must</strong> also contain <code>VK_BUFFER_CREATE_SPARSE_BINDING_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDedicatedAllocationBufferCreateInfoNV\">VkDedicatedAllocationBufferCreateInfoNV</a> or <a href=\"#VkExternalMemoryBufferCreateInfo\">VkExternalMemoryBufferCreateInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkBufferCreateFlagBits\">VkBufferCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkBufferUsageFlagBits\">VkBufferUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sharingMode-parameter",\r
+ "text": " <code>sharingMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSharingMode\">VkSharingMode</a> value"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sharingMode-01391",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, each element of <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be unique and <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties\">vkGetPhysicalDeviceQueueFamilyProperties</a> for the <code>physicalDevice</code> that was used to create <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-sharingMode-01419",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, each element of <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be unique and <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by either <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties\">vkGetPhysicalDeviceQueueFamilyProperties</a> or <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties2\">vkGetPhysicalDeviceQueueFamilyProperties2</a> for the <code>physicalDevice</code> that was used to create <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-pNext-00920",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkExternalMemoryBufferCreateInfo\">VkExternalMemoryBufferCreateInfo</a>, its <code>handleTypes</code> member <strong class=\"purple\">must</strong> only contain bits that are also in <a href=\"#VkExternalBufferProperties\">VkExternalBufferProperties</a>::<code>externalMemoryProperties.pname</code>:compatibleHandleTypes, as returned by <a href=\"#vkGetPhysicalDeviceExternalBufferProperties\">vkGetPhysicalDeviceExternalBufferProperties</a> with <code>pExternalBufferInfo</code>\\-&amp;gt;<code>handleType</code> equal to any one of the handle types specified in <a href=\"#VkExternalMemoryBufferCreateInfo\">VkExternalMemoryBufferCreateInfo</a>::<code>handleTypes</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-flags-01887",\r
+ "text": " If the protected memory feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_BUFFER_CREATE_PROTECTED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-None-01888",\r
+ "text": " If any of the bits <code>VK_BUFFER_CREATE_SPARSE_BINDING_BIT</code>, <code>VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT</code>, or <code>VK_BUFFER_CREATE_SPARSE_ALIASED_BIT</code> are set, <code>VK_BUFFER_CREATE_PROTECTED_BIT</code> <strong class=\"purple\">must</strong> not also be set"\r
+ }\r
+ ],\r
+ "(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBufferCreateInfo-pNext-01571",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkDedicatedAllocationBufferCreateInfoNV\">VkDedicatedAllocationBufferCreateInfoNV</a>, and the <code>dedicatedAllocation</code> member of the chained structure is <code>VK_TRUE</code>, then <code>flags</code> <strong class=\"purple\">must</strong> not include <code>VK_BUFFER_CREATE_SPARSE_BINDING_BIT</code>, <code>VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT</code>, or <code>VK_BUFFER_CREATE_SPARSE_ALIASED_BIT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDedicatedAllocationBufferCreateInfoNV": {\r
+ "(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationBufferCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalMemoryBufferCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryBufferCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryBufferCreateInfo-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-buffer-00922",\r
+ "text": " All submitted commands that refer to <code>buffer</code>, either directly or via a <code>VkBufferView</code>, <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-buffer-00923",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>buffer</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-buffer-00924",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>buffer</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-buffer-parameter",\r
+ "text": " If <code>buffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBuffer-buffer-parent",\r
+ "text": " If <code>buffer</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateBufferView": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateBufferView-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBufferView-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkBufferViewCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBufferView-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateBufferView-pView-parameter",\r
+ "text": " <code>pView</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkBufferView</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkBufferViewCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-offset-00925",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-offset-00926",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minTexelBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-range-00928",\r
+ "text": " If <code>range</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>range</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-range-00929",\r
+ "text": " If <code>range</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>range</code> <strong class=\"purple\">must</strong> be a multiple of the element size of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-range-00930",\r
+ "text": " If <code>range</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>range</code> divided by the element size of <code>format</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxTexelBufferElements</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-offset-00931",\r
+ "text": " If <code>range</code> is not equal to <code>VK_WHOLE_SIZE</code>, the sum of <code>offset</code> and <code>range</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-buffer-00932",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with a <code>usage</code> value containing at least one of <code>VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT</code> or <code>VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-buffer-00933",\r
+ "text": " If <code>buffer</code> was created with <code>usage</code> containing <code>VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for uniform texel buffers, as specified by the <code>VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT</code> flag in <code>VkFormatProperties</code>::<code>bufferFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-buffer-00934",\r
+ "text": " If <code>buffer</code> was created with <code>usage</code> containing <code>VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for storage texel buffers, as specified by the <code>VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT</code> flag in <code>VkFormatProperties</code>::<code>bufferFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-buffer-00935",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferViewCreateInfo-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyBufferView": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-bufferView-00936",\r
+ "text": " All submitted commands that refer to <code>bufferView</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-bufferView-00937",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>bufferView</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-bufferView-00938",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>bufferView</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-bufferView-parameter",\r
+ "text": " If <code>bufferView</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>bufferView</code> <strong class=\"purple\">must</strong> be a valid <code>VkBufferView</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyBufferView-bufferView-parent",\r
+ "text": " If <code>bufferView</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateImage": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateImage-flags-00939",\r
+ "text": " If the <code>flags</code> member of <code>pCreateInfo</code> includes <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code>, creating this <code>VkImage</code> <strong class=\"purple\">must</strong> not cause the total required sparse memory for all currently valid sparse resources on the device to exceed <code>VkPhysicalDeviceLimits</code>::<code>sparseAddressSpaceSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImage-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImage-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImageCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImage-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImage-pImage-parameter",\r
+ "text": " <code>pImage</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkImage</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageCreateInfo": {\r
+ "!(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-format-00940",\r
+ "text": " The combination of <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> <strong class=\"purple\">must</strong> be supported, as indicated by a <code>VK_SUCCESS</code> return value from <code>vkGetPhysicalDeviceImageFormatProperties</code> invoked with the same values passed to the corresponding parameters."\r
+ }\r
+ ],\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-01889",\r
+ "text": " If the <code>pNext</code> chain doesn’t contain an instance of <a href=\"#VkExternalFormatANDROID\">VkExternalFormatANDROID</a>, or if <code>format</code> is not VK_FORMAT_UNDEFINED, the combination of <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> <strong class=\"purple\">must</strong> be supported, as indicated by a <code>VK_SUCCESS</code> return value from <code>vkGetPhysicalDeviceImageFormatProperties</code> invoked with the same values passed to the corresponding parameters."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-01892",\r
+ "text": " If the <code>pNext</code> chain includes a <a href=\"#VkExternalMemoryImageCreateInfo\">VkExternalMemoryImageCreateInfo</a> structure whose <code>handleTypes</code> member includes <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID</code>:"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-01893",\r
+ "text": " If the <code>pNext</code> chain includes a <a href=\"#VkExternalFormatANDROID\">VkExternalFormatANDROID</a> structure whose <code>externalFormat</code> member is not <code>0</code>:"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sharingMode-00941",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>queueFamilyIndexCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sharingMode-00942",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, <code>queueFamilyIndexCount</code> <strong class=\"purple\">must</strong> be greater than <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-format-00943",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> not be <code>VK_FORMAT_UNDEFINED</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-extent-00944",\r
+ "text": " <code>extent</code>::<code>width</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-extent-00945",\r
+ "text": " <code>extent</code>::<code>height</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-extent-00946",\r
+ "text": " <code>extent</code>::<code>depth</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-mipLevels-00947",\r
+ "text": " <code>mipLevels</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-arrayLayers-00948",\r
+ "text": " <code>arrayLayers</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-00949",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT</code>, <code>imageType</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_TYPE_2D</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00951",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_1D</code>, <code>extent.width</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxImageDimension1D</code>, or <code>VkImageFormatProperties</code>::<code>maxExtent.width</code> (as returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure) - whichever is higher"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00952",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code> and <code>flags</code> does not contain <code>VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT</code>, <code>extent.width</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxImageDimension2D</code>, or <code>VkImageFormatProperties</code>::<code>maxExtent.width</code>/<code>height</code> (as returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure) - whichever is higher"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00953",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code> and <code>flags</code> contains <code>VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT</code>, <code>extent.width</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxImageDimensionCube</code>, or <code>VkImageFormatProperties</code>::<code>maxExtent.width</code>/<code>height</code> (as returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure) - whichever is higher"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00954",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code> and <code>flags</code> contains <code>VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT</code>, <code>extent.width</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be equal and <code>arrayLayers</code> <strong class=\"purple\">must</strong> be greater than or equal to 6"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00955",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_3D</code>, <code>extent.width</code>, <code>extent.height</code> and <code>extent.depth</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxImageDimension3D</code>, or <code>VkImageFormatProperties</code>::<code>maxExtent.width</code>/<code>height</code>/<code>depth</code> (as returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure) - whichever is higher"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00956",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_1D</code>, both <code>extent.height</code> and <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00957",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code>, <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-mipLevels-00958",\r
+ "text": " <code>mipLevels</code> <strong class=\"purple\">must</strong> be less than or equal to <span class=\"eq\">{lfloor}log<sub>2</sub>(max(<code>extent.width</code>, <code>extent.height</code>, <code>extent.depth</code>)){rfloor} + 1</span>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-extent-00959",\r
+ "text": " <code>mipLevels</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkImageFormatProperties</code>::<code>maxMipLevels</code> (as returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure)"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-arrayLayers-00960",\r
+ "text": " <code>arrayLayers</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkImageFormatProperties</code>::<code>maxArrayLayers</code> (as returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure)"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00961",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_3D</code>, <code>arrayLayers</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-samples-00962",\r
+ "text": " If <code>samples</code> is not <code>VK_SAMPLE_COUNT_1_BIT</code>, <code>imageType</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_TYPE_2D</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT</code>, <code>tiling</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_TILING_OPTIMAL</code>, and <code>mipLevels</code> <strong class=\"purple\">must</strong> be equal to <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-00963",\r
+ "text": " If <code>usage</code> includes <code>VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT</code>, then bits other than <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, and <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code> <strong class=\"purple\">must</strong> not be set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-00964",\r
+ "text": " If <code>usage</code> includes <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT</code>, or <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code>, <code>extent.width</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxFramebufferWidth</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-00965",\r
+ "text": " If <code>usage</code> includes <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT</code>, or <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code>, <code>extent.height</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxFramebufferHeight</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-00966",\r
+ "text": " If <code>usage</code> includes <code>VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT</code>, <code>usage</code> <strong class=\"purple\">must</strong> also contain at least one of <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, or <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-samples-00967",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a bit value that is set in <code>VkImageFormatProperties</code>::<code>sampleCounts</code> returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-00968",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-shaderStorageImageMultisample,multisampled storage images&amp;gt;&amp;gt; feature is not enabled, and <code>usage</code> contains <code>VK_IMAGE_USAGE_STORAGE_BIT</code>, <code>samples</code> <strong class=\"purple\">must</strong> be <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-00969",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseBinding,sparse bindings&amp;gt;&amp;gt; feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-01924",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidencyAliased,sparse aliased residency&amp;gt;&amp;gt; feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_ALIASED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00970",\r
+ "text": " If <code>imageType</code> is <code>VK_IMAGE_TYPE_1D</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00971",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidencyImage2D,sparse residency for 2D images&amp;gt;&amp;gt; feature is not enabled, and <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00972",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidencyImage3D,sparse residency for 3D images&amp;gt;&amp;gt; feature is not enabled, and <code>imageType</code> is <code>VK_IMAGE_TYPE_3D</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00973",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidency2Samples,sparse residency for images with 2 samples&amp;gt;&amp;gt; feature is not enabled, <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code>, and <code>samples</code> is <code>VK_SAMPLE_COUNT_2_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00974",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidency4Samples,sparse residency for images with 4 samples&amp;gt;&amp;gt; feature is not enabled, <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code>, and <code>samples</code> is <code>VK_SAMPLE_COUNT_4_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00975",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidency8Samples,sparse residency for images with 8 samples&amp;gt;&amp;gt; feature is not enabled, <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code>, and <code>samples</code> is <code>VK_SAMPLE_COUNT_8_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-00976",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidency16Samples,sparse residency for images with 16 samples&amp;gt;&amp;gt; feature is not enabled, <code>imageType</code> is <code>VK_IMAGE_TYPE_2D</code>, and <code>samples</code> is <code>VK_SAMPLE_COUNT_16_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-00987",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code> or <code>VK_IMAGE_CREATE_SPARSE_ALIASED_BIT</code>, it <strong class=\"purple\">must</strong> also contain <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-None-01925",\r
+ "text": " If any of the bits <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code>, <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>, or <code>VK_IMAGE_CREATE_SPARSE_ALIASED_BIT</code> are set, <code>VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT</code> <strong class=\"purple\">must</strong> not also be set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-initialLayout-00993",\r
+ "text": " <code>initialLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_UNDEFINED</code> or <code>VK_IMAGE_LAYOUT_PREINITIALIZED</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDedicatedAllocationImageCreateInfoNV\">VkDedicatedAllocationImageCreateInfoNV</a>, <a href=\"#VkExternalFormatANDROID\">VkExternalFormatANDROID</a>, <a href=\"#VkExternalMemoryImageCreateInfo\">VkExternalMemoryImageCreateInfo</a>, <a href=\"#VkExternalMemoryImageCreateInfoNV\">VkExternalMemoryImageCreateInfoNV</a>, <a href=\"#VkImageFormatListCreateInfoKHR\">VkImageFormatListCreateInfoKHR</a>, or <a href=\"#VkImageSwapchainCreateInfoKHR\">VkImageSwapchainCreateInfoKHR</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageCreateFlagBits\">VkImageCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-imageType-parameter",\r
+ "text": " <code>imageType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageType\">VkImageType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-samples-parameter",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-tiling-parameter",\r
+ "text": " <code>tiling</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageTiling\">VkImageTiling</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sharingMode-parameter",\r
+ "text": " <code>sharingMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSharingMode\">VkSharingMode</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-initialLayout-parameter",\r
+ "text": " <code>initialLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sharingMode-01392",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, each element of <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be unique and <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties\">vkGetPhysicalDeviceQueueFamilyProperties</a> for the <code>physicalDevice</code> that was used to create <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-sharingMode-01420",\r
+ "text": " If <code>sharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, each element of <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be unique and <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by either <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties\">vkGetPhysicalDeviceQueueFamilyProperties</a> or <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties2\">vkGetPhysicalDeviceQueueFamilyProperties2</a> for the <code>physicalDevice</code> that was used to create <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-00950",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT</code>, <code>imageType</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_TYPE_3D</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-01890",\r
+ "text": " If the protected memory feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_PROTECTED_BIT</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-None-01891",\r
+ "text": " If any of the bits <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code>, <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>, or <code>VK_IMAGE_CREATE_SPARSE_ALIASED_BIT</code> are set, <code>VK_IMAGE_CREATE_PROTECTED_BIT</code> <strong class=\"purple\">must</strong> not also be set."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)+(VK_NV_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-00988",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkExternalMemoryImageCreateInfoNV\">VkExternalMemoryImageCreateInfoNV</a>, it <strong class=\"purple\">must</strong> not contain an instance of <a href=\"#VkExternalMemoryImageCreateInfo\">VkExternalMemoryImageCreateInfo</a>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-00990",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkExternalMemoryImageCreateInfo\">VkExternalMemoryImageCreateInfo</a>, its <code>handleTypes</code> member <strong class=\"purple\">must</strong> only contain bits that are also in <a href=\"#VkExternalImageFormatProperties\">VkExternalImageFormatProperties</a>::<code>externalMemoryProperties</code>::<code>compatibleHandleTypes</code>, as returned by <a href=\"#vkGetPhysicalDeviceImageFormatProperties2\">vkGetPhysicalDeviceImageFormatProperties2</a> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure, and with an instance of <a href=\"#VkPhysicalDeviceExternalImageFormatInfo\">VkPhysicalDeviceExternalImageFormatInfo</a> in the <code>pNext</code> chain, with a <code>handleType</code> equal to any one of the handle types specified in <a href=\"#VkExternalMemoryImageCreateInfo\">VkExternalMemoryImageCreateInfo</a>::<code>handleTypes</code>"\r
+ }\r
+ ],\r
+ "(VK_NV_external_memory+VK_NV_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-00991",\r
+ "text": " If the <code>pNext</code> chain contains an instance of <a href=\"#VkExternalMemoryImageCreateInfoNV\">VkExternalMemoryImageCreateInfoNV</a>, its <code>handleTypes</code> member <strong class=\"purple\">must</strong> only contain bits that are also in <a href=\"#VkExternalImageFormatPropertiesNV\">VkExternalImageFormatPropertiesNV</a>::<code>externalMemoryProperties</code>::<code>compatibleHandleTypes</code>, as returned by <a href=\"#vkGetPhysicalDeviceExternalImageFormatPropertiesNV\">vkGetPhysicalDeviceExternalImageFormatPropertiesNV</a> with <code>format</code>, <code>imageType</code>, <code>tiling</code>, <code>usage</code>, and <code>flags</code> equal to those in this structure, and with <code>externalHandleType</code> equal to any one of the handle types specified in <a href=\"#VkExternalMemoryImageCreateInfoNV\">VkExternalMemoryImageCreateInfoNV</a>::<code>handleTypes</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-physicalDeviceCount-01421",\r
+ "text": " If the logical device was created with <a href=\"#VkDeviceGroupDeviceCreateInfo\">VkDeviceGroupDeviceCreateInfo</a>::<code>physicalDeviceCount</code> equal to 1, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-00992",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT</code>, then <code>mipLevels</code> <strong class=\"purple\">must</strong> be one, <code>arrayLayers</code> <strong class=\"purple\">must</strong> be one, <code>imageType</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_TYPE_2D</code>, and <code>tiling</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_TILING_OPTIMAL</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-01572",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT</code>, then <code>format</code> <strong class=\"purple\">must</strong> be a &amp;lt;&amp;lt;appendix-compressedtex-bc,block-compressed image format&amp;gt;&amp;gt;, an &amp;lt;&amp;lt;appendix-compressedtex-etc2, ETC compressed image format&amp;gt;&amp;gt;, or an &amp;lt;&amp;lt;appendix-compressedtex-astc, ASTC compressed image format&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-01573",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT</code>, then <code>flags</code> <strong class=\"purple\">must</strong> also contain <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory,VK_NV_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-pNext-01443",\r
+ "text": " If the <code>pNext</code> chain includes a ifdef::VK_VERSION_1_1,VK_KHR_external_memory[<a href=\"#VkExternalMemoryImageCreateInfo\">VkExternalMemoryImageCreateInfo</a>]"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-format-01574",\r
+ "text": " If the image <code>format</code> is one of those listed in &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion&amp;gt;&amp;gt;:"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-tiling-01575",\r
+ "text": " If <code>tiling</code> is <code>VK_IMAGE_TILING_OPTIMAL</code>, <code>format</code> is a <em>multi-planar</em> format, and <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (as returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>) does not include <code>VK_FORMAT_FEATURE_DISJOINT_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_DISJOINT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-tiling-01576",\r
+ "text": " If <code>tiling</code> is <code>VK_IMAGE_TILING_LINEAR</code>, <code>format</code> is a <em>multi-planar</em> format, and <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (as returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>) does not include <code>VK_FORMAT_FEATURE_DISJOINT_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_DISJOINT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-format-01577",\r
+ "text": " If <code>format</code> is not a <em>multi-planar</em> format, and <code>flags</code> does not include <code>VK_IMAGE_CREATE_ALIAS_BIT</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_CREATE_DISJOINT_BIT</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkImageCreateInfo-flags-01533",\r
+ "text": " If <code>flags</code> contains <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> <code>format</code> <strong class=\"purple\">must</strong> be a depth or depth/stencil format"\r
+ }\r
+ ]\r
+ },\r
+ "VkDedicatedAllocationImageCreateInfoNV": {\r
+ "(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationImageCreateInfoNV-dedicatedAllocation-00994",\r
+ "text": " If <code>dedicatedAllocation</code> is <code>VK_TRUE</code>, <code>VkImageCreateInfo</code>::<code>flags</code> <strong class=\"purple\">must</strong> not include <code>VK_IMAGE_CREATE_SPARSE_BINDING_BIT</code>, <code>VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT</code>, or <code>VK_IMAGE_CREATE_SPARSE_ALIASED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDedicatedAllocationImageCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalMemoryImageCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryImageCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryImageCreateInfo-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryImageCreateInfo-handleTypes-requiredbitmask",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalMemoryImageCreateInfoNV": {\r
+ "(VK_NV_external_memory)": [\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryImageCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalMemoryImageCreateInfoNV-handleTypes-parameter",\r
+ "text": " <code>handleTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBitsNV\">VkExternalMemoryHandleTypeFlagBitsNV</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalFormatANDROID": {\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkExternalFormatANDROID-externalFormat-01894",\r
+ "text": " <code>externalFormat</code> <strong class=\"purple\">must</strong> be <code>0</code> or a value returned in the <code>externalFormat</code> member of <a href=\"#VkAndroidHardwareBufferFormatPropertiesANDROID\">VkAndroidHardwareBufferFormatPropertiesANDROID</a> by an earlier call to <a href=\"#vkGetAndroidHardwareBufferPropertiesANDROID\">vkGetAndroidHardwareBufferPropertiesANDROID</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalFormatANDROID-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_FORMAT_ANDROID</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageSwapchainCreateInfoKHR": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-VkImageSwapchainCreateInfoKHR-swapchain-00995",\r
+ "text": " If <code>swapchain</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, the fields of <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> <strong class=\"purple\">must</strong> match the &amp;lt;&amp;lt;swapchain-wsi-image-create-info, implied image creation parameters&amp;gt;&amp;gt; of the swapchain"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSwapchainCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSwapchainCreateInfoKHR-swapchain-parameter",\r
+ "text": " If <code>swapchain</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageFormatListCreateInfoKHR": {\r
+ "(VK_KHR_image_format_list)": [\r
+ {\r
+ "vuid": "VUID-VkImageFormatListCreateInfoKHR-viewFormatCount-01578",\r
+ "text": " If <code>viewFormatCount</code> is not <code>0</code>, all of the formats in the <code>pViewFormats</code> array <strong class=\"purple\">must</strong> be compatible with the format specified in the <code>format</code> field of <code>VkImageCreateInfo</code>, as described in the <a href=\"#resources-image-views-compatibility\">compatibility table</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageFormatListCreateInfoKHR-flags-01579",\r
+ "text": " If <code>VkImageCreateInfo</code>::<code>flags</code> does not contain <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code>, <code>viewFormatCount</code> <strong class=\"purple\">must</strong> be <code>0</code> or <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageFormatListCreateInfoKHR-viewFormatCount-01580",\r
+ "text": " If <code>viewFormatCount</code> is not <code>0</code>, <code>VkImageCreateInfo</code>::<code>format</code> <strong class=\"purple\">must</strong> be in <code>pViewFormats</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageFormatListCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageFormatListCreateInfoKHR-pViewFormats-parameter",\r
+ "text": " If <code>viewFormatCount</code> is not <code>0</code>, <code>pViewFormats</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>viewFormatCount</code> valid <a href=\"#VkFormat\">VkFormat</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetImageSubresourceLayout": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-image-00996",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>tiling</code> equal to <code>VK_IMAGE_TILING_LINEAR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-aspectMask-00997",\r
+ "text": " The <code>aspectMask</code> member of <code>pSubresource</code> <strong class=\"purple\">must</strong> only have a single bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-mipLevel-01716",\r
+ "text": " The <code>mipLevel</code> member of <code>pSubresource</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-arrayLayer-01717",\r
+ "text": " The <code>arrayLayer</code> member of <code>pSubresource</code> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-pSubresource-parameter",\r
+ "text": " <code>pSubresource</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImageSubresource</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-pLayout-parameter",\r
+ "text": " <code>pLayout</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSubresourceLayout</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-image-parent",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-format-01581",\r
+ "text": " If the <code>format</code> of <code>image</code> is a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt; with two planes, the <code>aspectMask</code> member of <code>pSubresource</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-format-01582",\r
+ "text": " If the <code>format</code> of <code>image</code> is a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt; with three planes, the <code>aspectMask</code> member of <code>pSubresource</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ }\r
+ ],\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-vkGetImageSubresourceLayout-image-01895",\r
+ "text": " If <code>image</code> was created with the VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID external memory handle type, then <code>image</code> <strong class=\"purple\">must</strong> be bound to memory."\r
+ }\r
+ ]\r
+ },\r
+ "VkImageSubresource": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageSubresource-aspectMask-parameter",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresource-aspectMask-requiredbitmask",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyImage": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-image-01000",\r
+ "text": " All submitted commands that refer to <code>image</code>, either directly or via a <code>VkImageView</code>, <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-image-01001",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>image</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-image-01002",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>image</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-image-parameter",\r
+ "text": " If <code>image</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImage-image-parent",\r
+ "text": " If <code>image</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateImageView": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateImageView-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImageView-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImageViewCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImageView-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateImageView-pView-parameter",\r
+ "text": " <code>pView</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkImageView</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageViewCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01003",\r
+ "text": " If <code>image</code> was not created with <code>VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT</code> then <code>viewType</code> <strong class=\"purple\">must</strong> not be <code>VK_IMAGE_VIEW_TYPE_CUBE</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-viewType-01004",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-imageCubeArray,image cubemap arrays&amp;gt;&amp;gt; feature is not enabled, <code>viewType</code> <strong class=\"purple\">must</strong> not be <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01006",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_LINEAR</code>, <code>format</code> <strong class=\"purple\">must</strong> be format that has at least one supported feature bit present in the value of <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01007",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created with a <code>usage</code> value containing at least one of <code>VK_IMAGE_USAGE_SAMPLED_BIT</code>, <code>VK_IMAGE_USAGE_STORAGE_BIT</code>, <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, or <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01008",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_LINEAR</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_SAMPLED_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for sampled images, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01009",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_LINEAR</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_STORAGE_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for storage images, as specified by the <code>VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01010",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_LINEAR</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for color attachments, as specified by the <code>VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01011",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_LINEAR</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for depth/stencil attachments, as specified by the <code>VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01012",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_OPTIMAL</code>, <code>format</code> <strong class=\"purple\">must</strong> be format that has at least one supported feature bit present in the value of <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01013",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_OPTIMAL</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_SAMPLED_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for sampled images, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT</code> flag in <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01014",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_OPTIMAL</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_STORAGE_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for storage images, as specified by the <code>VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT</code> flag in <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01015",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_OPTIMAL</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for color attachments, as specified by the <code>VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT</code> flag in <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01016",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TILING_OPTIMAL</code> and <code>usage</code> contains <code>VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT</code>, <code>format</code> <strong class=\"purple\">must</strong> be supported for depth/stencil attachments, as specified by the <code>VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT</code> flag in <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code> with the same value of <code>format</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-01478",\r
+ "text": " <code>subresourceRange.baseMipLevel</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-01718",\r
+ "text": " If <code>subresourceRange.levelCount</code> is not <code>VK_REMAINING_MIP_LEVELS</code>, <span class=\"eq\"><code>subresourceRange.baseMipLevel</code> + <code>subresourceRange.levelCount</code></span> <strong class=\"purple\">must</strong> be less than or equal to the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01018",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag, <code>format</code> <strong class=\"purple\">must</strong> be compatible with the <code>format</code> used to create <code>image</code>, as defined in &amp;lt;&amp;lt;features-formats-compatibility-classes,Format Compatibility Classes&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01020",\r
+ "text": " If <code>image</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subResourceRange-01021",\r
+ "text": " <code>subresourceRange</code> and <code>viewType</code> <strong class=\"purple\">must</strong> be compatible with the image, as described in the &amp;lt;&amp;lt;resources-image-views-compatibility,compatibility table&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkImageViewUsageCreateInfo\">VkImageViewUsageCreateInfo</a> or <a href=\"#VkSamplerYcbcrConversionInfo\">VkSamplerYcbcrConversionInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-viewType-parameter",\r
+ "text": " <code>viewType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageViewType\">VkImageViewType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-components-parameter",\r
+ "text": " <code>components</code> <strong class=\"purple\">must</strong> be a valid <code>VkComponentMapping</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-parameter",\r
+ "text": " <code>subresourceRange</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceRange</code> structure"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01005",\r
+ "text": " If <code>image</code> was created with <code>VK_IMAGE_TYPE_3D</code> but without <code>VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT</code> set then <code>viewType</code> <strong class=\"purple\">must</strong> not be <code>VK_IMAGE_VIEW_TYPE_2D</code> or <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01482",\r
+ "text": " If <code>image</code> is not a 3D image created with <code>VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT</code> set, or <code>viewType</code> is not <code>VK_IMAGE_VIEW_TYPE_2D</code> or <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code>, <code>subresourceRange</code>::<code>baseArrayLayer</code> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-01483",\r
+ "text": " If <code>subresourceRange</code>::<code>layerCount</code> is not <code>VK_REMAINING_ARRAY_LAYERS</code>, <code>image</code> is not a 3D image created with <code>VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT</code> set, or <code>viewType</code> is not <code>VK_IMAGE_VIEW_TYPE_2D</code> or <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code>, <code>subresourceRange</code>::<code>layerCount</code> <strong class=\"purple\">must</strong> be non-zero and <span class=\"eq\"><code>subresourceRange</code>::<code>baseArrayLayer</code> + <code>subresourceRange</code>::<code>layerCount</code></span> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01484",\r
+ "text": " If <code>image</code> is a 3D image created with <code>VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT</code> set, and <code>viewType</code> is <code>VK_IMAGE_VIEW_TYPE_2D</code> or <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code>, <code>subresourceRange</code>::<code>baseArrayLayer</code> <strong class=\"purple\">must</strong> be less than the <code>extent.depth</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-01485",\r
+ "text": " If <code>subresourceRange</code>::<code>layerCount</code> is not <code>VK_REMAINING_ARRAY_LAYERS</code>, <code>image</code> is a 3D image created with <code>VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT</code> set, and <code>viewType</code> is <code>VK_IMAGE_VIEW_TYPE_2D</code> or <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code>, <code>subresourceRange</code>::<code>layerCount</code> <strong class=\"purple\">must</strong> be non-zero and <span class=\"eq\"><code>subresourceRange</code>::<code>baseArrayLayer</code> + <code>subresourceRange</code>::<code>layerCount</code></span> <strong class=\"purple\">must</strong> be less than or equal to the <code>extent.depth</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-01480",\r
+ "text": " <code>subresourceRange.baseArrayLayer</code> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-subresourceRange-01719",\r
+ "text": " If <code>subresourceRange.layerCount</code> is not <code>VK_REMAINING_ARRAY_LAYERS</code>, <span class=\"eq\"><code>subresourceRange.baseArrayLayer</code> + <code>subresourceRange.layerCount</code></span> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)+!(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01759",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag, but without the <code>VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT</code> flag, <code>format</code> <strong class=\"purple\">must</strong> be compatible with the <code>format</code> used to create <code>image</code>, as defined in &amp;lt;&amp;lt;features-formats-compatibility-classes,Format Compatibility Classes&amp;gt;&amp;gt;"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01760",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag, and if the <code>format</code> of the <code>image</code> is not a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar&amp;gt;&amp;gt; format, <code>format</code> <strong class=\"purple\">must</strong> be compatible with the <code>format</code> used to create <code>image</code>, as defined in &amp;lt;&amp;lt;features-formats-compatibility-classes,Format Compatibility Classes&amp;gt;&amp;gt;"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01761",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag, but without the <code>VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT</code> flag, and if the <code>format</code> of the <code>image</code> is not a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar&amp;gt;&amp;gt; format, <code>format</code> <strong class=\"purple\">must</strong> be compatible with the <code>format</code> used to create <code>image</code>, as defined in &amp;lt;&amp;lt;features-formats-compatibility-classes,Format Compatibility Classes&amp;gt;&amp;gt;"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01583",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT</code> flag, <code>format</code> <strong class=\"purple\">must</strong> be compatible with, or <strong class=\"purple\">must</strong> be an uncompressed format that is size-compatible with, the <code>format</code> used to create <code>image</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01584",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT</code> flag, the <code>levelCount</code> and <code>layerCount</code> members of <code>subresourceRange</code> <strong class=\"purple\">must</strong> both be <code>1</code>."\r
+ }\r
+ ],\r
+ "(VK_KHR_image_format_list)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-pNext-01585",\r
+ "text": " If a <code>VkImageFormatListCreateInfoKHR</code> structure was included in the <code>pNext</code> chain of the <code>VkImageCreateInfo</code> struct used when creating <code>image</code> and the <code>viewFormatCount</code> field of <code>VkImageFormatListCreateInfoKHR</code> is not zero then <code>format</code> <strong class=\"purple\">must</strong> be one of the formats in <code>VkImageFormatListCreateInfoKHR</code>::<code>pViewFormats</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01586",\r
+ "text": " If <code>image</code> was created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag, if the <code>format</code> of the <code>image</code> is a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar&amp;gt;&amp;gt; format, and if <code>subresourceRange.aspectMask</code> is one of <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>, then <code>format</code> <strong class=\"purple\">must</strong> be compatible with the <a href=\"#VkFormat\">VkFormat</a> for the plane of the <code>image</code> <code>format</code> indicated by <code>subresourceRange.aspectMask</code>, as defined in &amp;lt;&amp;lt;features-formats-compatible-planes&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01762",\r
+ "text": " If <code>image</code> was not created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag,"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01019",\r
+ "text": " If <code>image</code> was not created with the <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code> flag, <code>format</code> <strong class=\"purple\">must</strong> be identical to the <code>format</code> used to create <code>image</code>"\r
+ }\r
+ ],\r
+ "(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewCreateInfo-image-01896",\r
+ "text": " If <code>image</code> has an &amp;lt;&amp;lt;memory-external-android-hardware-buffer-external-formats,external format&amp;gt;&amp;gt;:"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageViewUsageCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkImageViewUsageCreateInfo-usage-01587",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not include any set bits that were not set in the <code>usage</code> member of the <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> structure used to create the image this image view is created from."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewUsageCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewUsageCreateInfo-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageViewUsageCreateInfo-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageSubresourceRange": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceRange-levelCount-01720",\r
+ "text": " If <code>levelCount</code> is not <code>VK_REMAINING_MIP_LEVELS</code>, it <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceRange-layerCount-01721",\r
+ "text": " If <code>layerCount</code> is not <code>VK_REMAINING_ARRAY_LAYERS</code>, it <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceRange-aspectMask-parameter",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceRange-aspectMask-requiredbitmask",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceRange-aspectMask-01670",\r
+ "text": " If <code>aspectMask</code> includes <code>VK_IMAGE_ASPECT_COLOR_BIT</code>, then it <strong class=\"purple\">must</strong> not include any of <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkComponentMapping": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkComponentMapping-r-parameter",\r
+ "text": " <code>r</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkComponentSwizzle\">VkComponentSwizzle</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComponentMapping-g-parameter",\r
+ "text": " <code>g</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkComponentSwizzle\">VkComponentSwizzle</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComponentMapping-b-parameter",\r
+ "text": " <code>b</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkComponentSwizzle\">VkComponentSwizzle</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkComponentMapping-a-parameter",\r
+ "text": " <code>a</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkComponentSwizzle\">VkComponentSwizzle</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyImageView": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-imageView-01026",\r
+ "text": " All submitted commands that refer to <code>imageView</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-imageView-01027",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>imageView</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-imageView-01028",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>imageView</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-imageView-parameter",\r
+ "text": " If <code>imageView</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>imageView</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageView</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyImageView-imageView-parent",\r
+ "text": " If <code>imageView</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetBufferMemoryRequirements": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements-pMemoryRequirements-parameter",\r
+ "text": " <code>pMemoryRequirements</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryRequirements</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements-buffer-parent",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetImageMemoryRequirements": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements-image-01588",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not have been created with the <code>VK_IMAGE_CREATE_DISJOINT_BIT</code> flag set"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements-pMemoryRequirements-parameter",\r
+ "text": " <code>pMemoryRequirements</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryRequirements</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements-image-parent",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetBufferMemoryRequirements2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements2-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements2-pInfo-parameter",\r
+ "text": " <code>pInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkBufferMemoryRequirementsInfo2</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetBufferMemoryRequirements2-pMemoryRequirements-parameter",\r
+ "text": " <code>pMemoryRequirements</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryRequirements2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkBufferMemoryRequirementsInfo2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryRequirementsInfo2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryRequirementsInfo2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferMemoryRequirementsInfo2-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetImageMemoryRequirements2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements2-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements2-pInfo-parameter",\r
+ "text": " <code>pInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImageMemoryRequirementsInfo2</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageMemoryRequirements2-pMemoryRequirements-parameter",\r
+ "text": " <code>pMemoryRequirements</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMemoryRequirements2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageMemoryRequirementsInfo2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-image-01589",\r
+ "text": " If <code>image</code> was created with a <em>multi-planar</em> format and the <code>VK_IMAGE_CREATE_DISJOINT_BIT</code> flag, there <strong class=\"purple\">must</strong> be a <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a> in the <code>pNext</code> chain of the <a href=\"#VkImageMemoryRequirementsInfo2\">VkImageMemoryRequirementsInfo2</a> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-image-01590",\r
+ "text": " If <code>image</code> was not created with the <code>VK_IMAGE_CREATE_DISJOINT_BIT</code> flag, there <strong class=\"purple\">must</strong> not be a <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a> in the <code>pNext</code> chain of the <a href=\"#VkImageMemoryRequirementsInfo2\">VkImageMemoryRequirementsInfo2</a> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-image-01591",\r
+ "text": " If <code>image</code> was created with a single-plane format, there <strong class=\"purple\">must</strong> not be a <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a> in the <code>pNext</code> chain of the <a href=\"#VkImageMemoryRequirementsInfo2\">VkImageMemoryRequirementsInfo2</a> structure"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)+(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-image-01897",\r
+ "text": " If <code>image</code> was created with the VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID external memory handle type, then <code>image</code> <strong class=\"purple\">must</strong> be bound to memory."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageMemoryRequirementsInfo2-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkImagePlaneMemoryRequirementsInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImagePlaneMemoryRequirementsInfo-planeAspect-01592",\r
+ "text": " <code>planeAspect</code> <strong class=\"purple\">must</strong> be an aspect that exists in the format; that is, for a two-plane image <code>planeAspect</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, and for a three-plane image <code>planeAspect</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImagePlaneMemoryRequirementsInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImagePlaneMemoryRequirementsInfo-planeAspect-parameter",\r
+ "text": " <code>planeAspect</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryRequirements2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryRequirements2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMemoryRequirements2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkMemoryDedicatedRequirements\">VkMemoryDedicatedRequirements</a>"\r
+ }\r
+ ]\r
+ },\r
+ "VkMemoryDedicatedRequirements": {\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkMemoryDedicatedRequirements-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkBindBufferMemory": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01029",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> not already be backed by a memory object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01030",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> not have been created with any sparse memory binding flags"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-memoryOffset-01031",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01032",\r
+ "text": " If <code>buffer</code> was created with the <code>VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT</code> or <code>VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</code>, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minTexelBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01033",\r
+ "text": " If <code>buffer</code> was created with the <code>VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT</code>, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minUniformBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01034",\r
+ "text": " If <code>buffer</code> was created with the <code>VK_BUFFER_USAGE_STORAGE_BUFFER_BIT</code>, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minStorageBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-memory-01035",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been allocated using one of the memory types allowed in the <code>memoryTypeBits</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetBufferMemoryRequirements</code> with <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-memoryOffset-01036",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be an integer multiple of the <code>alignment</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetBufferMemoryRequirements</code> with <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-size-01037",\r
+ "text": " The <code>size</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetBufferMemoryRequirements</code> with <code>buffer</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>memory</code> minus <code>memoryOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-parent",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-memory-parent",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01444",\r
+ "text": " If <code>buffer</code> requires a dedicated allocation(as reported by <a href=\"#vkGetBufferMemoryRequirements2\">vkGetBufferMemoryRequirements2</a> in <a href=\"#VkMemoryDedicatedRequirements\">VkMemoryDedicatedRequirements</a>::requiresDedicatedAllocation for <code>buffer</code>), <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>buffer</code> equal to <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-memory-01508",\r
+ "text": " If the <code>VkMemoryAllocateInfo</code> provided when <code>memory</code> was allocated included an instance of <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a> in its <code>pNext</code> chain, and <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>buffer</code> was not <code>VK_NULL_HANDLE</code>, then <code>buffer</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>buffer</code>, and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-None-01898",\r
+ "text": " If buffer was created with the <code>VK_BUFFER_CREATE_PROTECTED_BIT</code> bit set, the buffer <strong class=\"purple\">must</strong> be bound to a memory object allocated with a memory type that reports <code>VK_MEMORY_PROPERTY_PROTECTED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-None-01899",\r
+ "text": " If buffer was created with the <code>VK_BUFFER_CREATE_PROTECTED_BIT</code> bit not set, the buffer <strong class=\"purple\">must</strong> not be bound to a memory object created with a memory type that reports <code>VK_MEMORY_PROPERTY_PROTECTED_BIT</code>"\r
+ }\r
+ ],\r
+ "(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01038",\r
+ "text": " If <code>buffer</code> was created with <a href=\"#VkDedicatedAllocationBufferCreateInfoNV\">VkDedicatedAllocationBufferCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkDedicatedAllocationMemoryAllocateInfoNV\">VkDedicatedAllocationMemoryAllocateInfoNV</a>::<code>buffer</code> equal to a buffer handle created with identical creation parameters to <code>buffer</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero"\r
+ }\r
+ ],\r
+ "(VK_NV_dedicated_allocation)+!(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory-buffer-01039",\r
+ "text": " If <code>buffer</code> was not created with <a href=\"#VkDedicatedAllocationBufferCreateInfoNV\">VkDedicatedAllocationBufferCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> not have been allocated dedicated for a specific buffer or image"\r
+ }\r
+ ]\r
+ },\r
+ "vkBindBufferMemory2": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)": [\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory2-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory2-pBindInfos-parameter",\r
+ "text": " <code>pBindInfos</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindInfoCount</code> valid <code>VkBindBufferMemoryInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindBufferMemory2-bindInfoCount-arraylength",\r
+ "text": " <code>bindInfoCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindBufferMemoryInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)": [\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01593",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> not already be backed by a memory object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01594",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> not have been created with any sparse memory binding flags"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-memoryOffset-01595",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01596",\r
+ "text": " If <code>buffer</code> was created with the <code>VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT</code> or <code>VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</code>, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minTexelBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01597",\r
+ "text": " If <code>buffer</code> was created with the <code>VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT</code>, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minUniformBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01598",\r
+ "text": " If <code>buffer</code> was created with the <code>VK_BUFFER_USAGE_STORAGE_BUFFER_BIT</code>, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minStorageBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-memory-01599",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been allocated using one of the memory types allowed in the <code>memoryTypeBits</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetBufferMemoryRequirements</code> with <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-memoryOffset-01600",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be an integer multiple of the <code>alignment</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetBufferMemoryRequirements</code> with <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-size-01601",\r
+ "text": " The <code>size</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetBufferMemoryRequirements</code> with <code>buffer</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>memory</code> minus <code>memoryOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkBindBufferMemoryDeviceGroupInfo\">VkBindBufferMemoryDeviceGroupInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01602",\r
+ "text": " If <code>buffer</code> requires a dedicated allocation(as reported by <a href=\"#vkGetBufferMemoryRequirements2\">vkGetBufferMemoryRequirements2</a> in <a href=\"#VkMemoryDedicatedRequirements\">VkMemoryDedicatedRequirements</a>::requiresDedicatedAllocation for <code>buffer</code>), <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>buffer</code> equal to <code>buffer</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-memory-01900",\r
+ "text": " If the <code>VkMemoryAllocateInfo</code> provided when <code>memory</code> was allocated included an instance of <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a> in its <code>pNext</code> chain, and <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>buffer</code> was not <code>VK_NULL_HANDLE</code>, then <code>buffer</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>buffer</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01603",\r
+ "text": " If <code>buffer</code> was created with <a href=\"#VkDedicatedAllocationBufferCreateInfoNV\">VkDedicatedAllocationBufferCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkDedicatedAllocationMemoryAllocateInfoNV\">VkDedicatedAllocationMemoryAllocateInfoNV</a>::<code>buffer</code> equal to <code>buffer</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_NV_dedicated_allocation)+!(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-buffer-01604",\r
+ "text": " If <code>buffer</code> was not created with <a href=\"#VkDedicatedAllocationBufferCreateInfoNV\">VkDedicatedAllocationBufferCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> not have been allocated dedicated for a specific buffer or image"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryInfo-pNext-01605",\r
+ "text": " If the <code>pNext</code> chain includes <a href=\"#VkBindBufferMemoryDeviceGroupInfo\">VkBindBufferMemoryDeviceGroupInfo</a>, all instances of <code>memory</code> specified by <a href=\"#VkBindBufferMemoryDeviceGroupInfo\">VkBindBufferMemoryDeviceGroupInfo</a>::<code>pDeviceIndices</code> <strong class=\"purple\">must</strong> have been allocated"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindBufferMemoryDeviceGroupInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryDeviceGroupInfo-deviceIndexCount-01606",\r
+ "text": " <code>deviceIndexCount</code> <strong class=\"purple\">must</strong> either be zero or equal to the number of physical devices in the logical device"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryDeviceGroupInfo-pDeviceIndices-01607",\r
+ "text": " All elements of <code>pDeviceIndices</code> <strong class=\"purple\">must</strong> be valid device indices"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryDeviceGroupInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindBufferMemoryDeviceGroupInfo-pDeviceIndices-parameter",\r
+ "text": " If <code>deviceIndexCount</code> is not <code>0</code>, <code>pDeviceIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>deviceIndexCount</code> <code>uint32_t</code> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkBindImageMemory": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-01608",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not have been created with the <code>VK_IMAGE_CREATE_DISJOINT_BIT</code> set."\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-01044",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not already be backed by a memory object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-01045",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not have been created with any sparse memory binding flags"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-memoryOffset-01046",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-memory-01047",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been allocated using one of the memory types allowed in the <code>memoryTypeBits</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetImageMemoryRequirements</code> with <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-memoryOffset-01048",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be an integer multiple of the <code>alignment</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetImageMemoryRequirements</code> with <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-size-01049",\r
+ "text": " The <code>size</code> member of the <code>VkMemoryRequirements</code> structure returned from a call to <code>vkGetImageMemoryRequirements</code> with <code>image</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>memory</code> minus <code>memoryOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-memory-parameter",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-parent",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-memory-parent",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-01445",\r
+ "text": " If <code>image</code> requires a dedicated allocation (as reported by <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> in <a href=\"#VkMemoryDedicatedRequirements\">VkMemoryDedicatedRequirements</a>::requiresDedicatedAllocation for <code>image</code>), <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>image</code> equal to <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-memory-01509",\r
+ "text": " If the <code>VkMemoryAllocateInfo</code> provided when <code>memory</code> was allocated included an instance of <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a> in its <code>pNext</code> chain, and <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>image</code> was not <code>VK_NULL_HANDLE</code>, then <code>image</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>image</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-None-01901",\r
+ "text": " If image was created with the <code>VK_IMAGE_CREATE_PROTECTED_BIT</code> bit set, the image <strong class=\"purple\">must</strong> be bound to a memory object allocated with a memory type that reports <code>VK_MEMORY_PROPERTY_PROTECTED_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-None-01902",\r
+ "text": " If image was created with the <code>VK_IMAGE_CREATE_PROTECTED_BIT</code> bit not set, the image <strong class=\"purple\">must</strong> not be bound to a memory object created with a memory type that reports <code>VK_MEMORY_PROPERTY_PROTECTED_BIT</code>"\r
+ }\r
+ ],\r
+ "(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-01050",\r
+ "text": " If <code>image</code> was created with <a href=\"#VkDedicatedAllocationImageCreateInfoNV\">VkDedicatedAllocationImageCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkDedicatedAllocationMemoryAllocateInfoNV\">VkDedicatedAllocationMemoryAllocateInfoNV</a>::<code>image</code> equal to an image handle created with identical creation parameters to <code>image</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero"\r
+ }\r
+ ],\r
+ "(VK_NV_dedicated_allocation)+!(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory-image-01051",\r
+ "text": " If <code>image</code> was not created with <a href=\"#VkDedicatedAllocationImageCreateInfoNV\">VkDedicatedAllocationImageCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> not have been allocated dedicated for a specific buffer or image"\r
+ }\r
+ ]\r
+ },\r
+ "vkBindImageMemory2": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)": [\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory2-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory2-pBindInfos-parameter",\r
+ "text": " <code>pBindInfos</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindInfoCount</code> valid <code>VkBindImageMemoryInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkBindImageMemory2-bindInfoCount-arraylength",\r
+ "text": " <code>bindInfoCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindImageMemoryInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-01609",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not already be backed by a memory object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-01610",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not have been created with any sparse memory binding flags"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-memoryOffset-01611",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>, <a href=\"#VkBindImageMemorySwapchainInfoKHR\">VkBindImageMemorySwapchainInfoKHR</a>, or <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-commonparent",\r
+ "text": " Both of <code>image</code>, and <code>memory</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+!(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-memory-01612",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> have been allocated using one of the memory types allowed in the <code>memoryTypeBits</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements\">vkGetImageMemoryRequirements</a> with <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-memoryOffset-01613",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be an integer multiple of the <code>alignment</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements\">vkGetImageMemoryRequirements</a> with <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-memory-01614",\r
+ "text": " The difference of the size of <code>memory</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be greater than or equal to the <code>size</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements\">vkGetImageMemoryRequirements</a> with the same <code>image</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01615",\r
+ "text": " If the <code>pNext</code> chain does not include an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, <code>memory</code> <strong class=\"purple\">must</strong> have been allocated using one of the memory types allowed in the <code>memoryTypeBits</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> with <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01616",\r
+ "text": " If the <code>pNext</code> chain does not include an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be an integer multiple of the <code>alignment</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> with <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01617",\r
+ "text": " If the <code>pNext</code> chain does not include an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, the difference of the size of <code>memory</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be greater than or equal to the <code>size</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> with the same <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01618",\r
+ "text": " If the <code>pNext</code> chain includes an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, <code>image</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_DISJOINT_BIT</code> bit set."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01619",\r
+ "text": " If the <code>pNext</code> chain includes an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, <code>memory</code> <strong class=\"purple\">must</strong> have been allocated using one of the memory types allowed in the <code>memoryTypeBits</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> with <code>image</code> and the correct <code>planeAspect</code> for this plane in the <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a> structure attached to the <a href=\"#VkImageMemoryRequirementsInfo2\">VkImageMemoryRequirementsInfo2</a>’s <code>pNext</code> chain"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01620",\r
+ "text": " If the <code>pNext</code> chain includes an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, <code>memoryOffset</code> <strong class=\"purple\">must</strong> be an integer multiple of the <code>alignment</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> with <code>image</code> and the correct <code>planeAspect</code> for this plane in the <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a> structure attached to the <a href=\"#VkImageMemoryRequirementsInfo2\">VkImageMemoryRequirementsInfo2</a>’s <code>pNext</code> chain"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01621",\r
+ "text": " If the <code>pNext</code> chain includes an instance of the <a href=\"#VkBindImagePlaneMemoryInfo\">VkBindImagePlaneMemoryInfo</a> structure, the difference of the size of <code>memory</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be greater than or equal to the <code>size</code> member of the <a href=\"#VkMemoryRequirements\">VkMemoryRequirements</a> structure returned from a call to <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> with the same <code>image</code> and the correct <code>planeAspect</code> for this plane in the <a href=\"#VkImagePlaneMemoryRequirementsInfo\">VkImagePlaneMemoryRequirementsInfo</a> structure attached to the <a href=\"#VkImageMemoryRequirementsInfo2\">VkImageMemoryRequirementsInfo2</a>’s <code>pNext</code> chain"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-01622",\r
+ "text": " If <code>image</code> requires a dedicated allocation (as reported by <a href=\"#vkGetImageMemoryRequirements2\">vkGetImageMemoryRequirements2</a> in <a href=\"#VkMemoryDedicatedRequirements\">VkMemoryDedicatedRequirements</a>::requiresDedicatedAllocation for <code>image</code>), <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>image</code> equal to <code>image</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-memory-01903",\r
+ "text": " If the <code>VkMemoryAllocateInfo</code> provided when <code>memory</code> was allocated included an instance of <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a> in its <code>pNext</code> chain, and <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>image</code> was not <code>VK_NULL_HANDLE</code>, then <code>image</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkMemoryDedicatedAllocateInfo\">VkMemoryDedicatedAllocateInfo</a>::<code>image</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_NV_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-01623",\r
+ "text": " If <code>image</code> was created with <a href=\"#VkDedicatedAllocationImageCreateInfoNV\">VkDedicatedAllocationImageCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> have been created with <a href=\"#VkDedicatedAllocationMemoryAllocateInfoNV\">VkDedicatedAllocationMemoryAllocateInfoNV</a>::<code>image</code> equal to <code>image</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> be zero"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_NV_dedicated_allocation)+!(VK_VERSION_1_1,VK_KHR_dedicated_allocation)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-01624",\r
+ "text": " If <code>image</code> was not created with <a href=\"#VkDedicatedAllocationImageCreateInfoNV\">VkDedicatedAllocationImageCreateInfoNV</a>::<code>dedicatedAllocation</code> equal to <code>VK_TRUE</code>, <code>memory</code> <strong class=\"purple\">must</strong> not have been allocated dedicated for a specific buffer or image"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+!(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-memory-01625",\r
+ "text": " <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01626",\r
+ "text": " If the <code>pNext</code> chain includes <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>, all instances of <code>memory</code> specified by <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>::<code>pDeviceIndices</code> <strong class=\"purple\">must</strong> have been allocated"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01627",\r
+ "text": " If the <code>pNext</code> chain includes <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>, and <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>::<code>splitInstanceBindRegionCount</code> is not zero, then <code>image</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01628",\r
+ "text": " If the <code>pNext</code> chain includes <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>, all elements of <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>::<code>pSplitInstanceBindRegions</code> <strong class=\"purple\">must</strong> be valid rectangles contained within the dimensions of <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01629",\r
+ "text": " If the <code>pNext</code> chain includes <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>, the union of the areas of all elements of <a href=\"#VkBindImageMemoryDeviceGroupInfo\">VkBindImageMemoryDeviceGroupInfo</a>::<code>pSplitInstanceBindRegions</code> that correspond to the same instance of <code>image</code> <strong class=\"purple\">must</strong> cover the entire image."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_device_group)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-image-01630",\r
+ "text": " If <code>image</code> was created with a valid swapchain handle in <a href=\"#VkImageSwapchainCreateInfoKHR\">VkImageSwapchainCreateInfoKHR</a>::<code>swapchain</code>, then the <code>pNext</code> chain <strong class=\"purple\">must</strong> include a valid instance of <a href=\"#VkBindImageMemorySwapchainInfoKHR\">VkBindImageMemorySwapchainInfoKHR</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01631",\r
+ "text": " If the <code>pNext</code> chain includes an instance of <a href=\"#VkBindImageMemorySwapchainInfoKHR\">VkBindImageMemorySwapchainInfoKHR</a>, <code>memory</code> <strong class=\"purple\">must</strong> be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryInfo-pNext-01632",\r
+ "text": " If the <code>pNext</code> chain does not include an instance of <a href=\"#VkBindImageMemorySwapchainInfoKHR\">VkBindImageMemorySwapchainInfoKHR</a>, <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindImageMemoryDeviceGroupInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-deviceIndexCount-01633",\r
+ "text": " At least one of <code>deviceIndexCount</code> and <code>splitInstanceBindRegionCount</code> <strong class=\"purple\">must</strong> be zero."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-deviceIndexCount-01634",\r
+ "text": " <code>deviceIndexCount</code> <strong class=\"purple\">must</strong> either be zero or equal to the number of physical devices in the logical device"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-pDeviceIndices-01635",\r
+ "text": " All elements of <code>pDeviceIndices</code> <strong class=\"purple\">must</strong> be valid device indices."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-splitInstanceBindRegionCount-01636",\r
+ "text": " <code>splitInstanceBindRegionCount</code> <strong class=\"purple\">must</strong> either be zero or equal to the number of physical devices in the logical device squared"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-pSplitInstanceBindRegions-01637",\r
+ "text": " Elements of <code>pSplitInstanceBindRegions</code> that correspond to the same instance of an image <strong class=\"purple\">must</strong> not overlap."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-offset-01638",\r
+ "text": " The <code>offset.x</code> member of any element of <code>pSplitInstanceBindRegions</code> <strong class=\"purple\">must</strong> be a multiple of the sparse image block width (<code>VkSparseImageFormatProperties</code>::<code>imageGranularity.width</code>) of all non-metadata aspects of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-offset-01639",\r
+ "text": " The <code>offset.y</code> member of any element of <code>pSplitInstanceBindRegions</code> <strong class=\"purple\">must</strong> be a multiple of the sparse image block height (<code>VkSparseImageFormatProperties</code>::<code>imageGranularity.height</code>) of all non-metadata aspects of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-extent-01640",\r
+ "text": " The <code>extent.width</code> member of any element of <code>pSplitInstanceBindRegions</code> <strong class=\"purple\">must</strong> either be a multiple of the sparse image block width of all non-metadata aspects of the image, or else <code>extent.width</code> + <code>offset.x</code> <strong class=\"purple\">must</strong> equal the width of the image subresource"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-extent-01641",\r
+ "text": " The <code>extent.height</code> member of any element of <code>pSplitInstanceBindRegions</code> <strong class=\"purple\">must</strong> either be a multiple of the sparse image block height of all non-metadata aspects of the image, or else <code>extent.height</code><br> <code>offset.y</code> <strong class=\"purple\">must</strong> equal the width of the image subresource"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-pDeviceIndices-parameter",\r
+ "text": " If <code>deviceIndexCount</code> is not <code>0</code>, <code>pDeviceIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>deviceIndexCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemoryDeviceGroupInfo-pSplitInstanceBindRegions-parameter",\r
+ "text": " If <code>splitInstanceBindRegionCount</code> is not <code>0</code>, <code>pSplitInstanceBindRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>splitInstanceBindRegionCount</code> <code>VkRect2D</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindImageMemorySwapchainInfoKHR": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_device_group)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-VkBindImageMemorySwapchainInfoKHR-imageIndex-01644",\r
+ "text": " <code>imageIndex</code> <strong class=\"purple\">must</strong> be less than the number of images in <code>swapchain</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemorySwapchainInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImageMemorySwapchainInfoKHR-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindImagePlaneMemoryInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_bind_memory2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkBindImagePlaneMemoryInfo-planeAspect-01642",\r
+ "text": " <code>planeAspect</code> <strong class=\"purple\">must</strong> be a single valid plane aspect for the image format (that is, <code>planeAspect</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code> for “<code>_2PLANE</code>” formats and <code>planeAspect</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code> for “<code>_3PLANE</code>” formats)"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImagePlaneMemoryInfo-None-01643",\r
+ "text": " A single call to <a href=\"#vkBindImageMemory2\">vkBindImageMemory2</a> <strong class=\"purple\">must</strong> bind all or none of the planes of an image (i.e. bindings to all planes of an image <strong class=\"purple\">must</strong> be made in a single <a href=\"#vkBindImageMemory2\">vkBindImageMemory2</a> call), as separate bindings"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImagePlaneMemoryInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindImagePlaneMemoryInfo-planeAspect-parameter",\r
+ "text": " <code>planeAspect</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateSampler": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateSampler-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSampler-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSamplerCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSampler-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSampler-pSampler-parameter",\r
+ "text": " <code>pSampler</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSampler</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkSamplerCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-mipLodBias-01069",\r
+ "text": " The absolute value of <code>mipLodBias</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxSamplerLodBias</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-anisotropyEnable-01070",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-samplerAnisotropy,anisotropic sampling&amp;gt;&amp;gt; feature is not enabled, <code>anisotropyEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-anisotropyEnable-01071",\r
+ "text": " If <code>anisotropyEnable</code> is <code>VK_TRUE</code>, <code>maxAnisotropy</code> <strong class=\"purple\">must</strong> be between <code>1.0</code> and <code>VkPhysicalDeviceLimits</code>::<code>maxSamplerAnisotropy</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-unnormalizedCoordinates-01072",\r
+ "text": " If <code>unnormalizedCoordinates</code> is <code>VK_TRUE</code>, <code>minFilter</code> and <code>magFilter</code> <strong class=\"purple\">must</strong> be equal"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-unnormalizedCoordinates-01073",\r
+ "text": " If <code>unnormalizedCoordinates</code> is <code>VK_TRUE</code>, <code>mipmapMode</code> <strong class=\"purple\">must</strong> be <code>VK_SAMPLER_MIPMAP_MODE_NEAREST</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-unnormalizedCoordinates-01074",\r
+ "text": " If <code>unnormalizedCoordinates</code> is <code>VK_TRUE</code>, <code>minLod</code> and <code>maxLod</code> <strong class=\"purple\">must</strong> be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-unnormalizedCoordinates-01075",\r
+ "text": " If <code>unnormalizedCoordinates</code> is <code>VK_TRUE</code>, <code>addressModeU</code> and <code>addressModeV</code> <strong class=\"purple\">must</strong> each be either <code>VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE</code> or <code>VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-unnormalizedCoordinates-01076",\r
+ "text": " If <code>unnormalizedCoordinates</code> is <code>VK_TRUE</code>, <code>anisotropyEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-unnormalizedCoordinates-01077",\r
+ "text": " If <code>unnormalizedCoordinates</code> is <code>VK_TRUE</code>, <code>compareEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-addressModeU-01078",\r
+ "text": " If any of <code>addressModeU</code>, <code>addressModeV</code> or <code>addressModeW</code> are <code>VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER</code>, <code>borderColor</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBorderColor\">VkBorderColor</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-addressModeU-01079",\r
+ "text": " If the <code><a href=\"#VK_KHR_sampler_mirror_clamp_to_edge\">VK_KHR_sampler_mirror_clamp_to_edge</a></code> extension is not enabled, <code>addressModeU</code>, <code>addressModeV</code> and <code>addressModeW</code> <strong class=\"purple\">must</strong> not be <code>VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-compareEnable-01080",\r
+ "text": " If <code>compareEnable</code> is <code>VK_TRUE</code>, <code>compareOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkCompareOp\">VkCompareOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkSamplerReductionModeCreateInfoEXT\">VkSamplerReductionModeCreateInfoEXT</a> or <a href=\"#VkSamplerYcbcrConversionInfo\">VkSamplerYcbcrConversionInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-magFilter-parameter",\r
+ "text": " <code>magFilter</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFilter\">VkFilter</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-minFilter-parameter",\r
+ "text": " <code>minFilter</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFilter\">VkFilter</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-mipmapMode-parameter",\r
+ "text": " <code>mipmapMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerMipmapMode\">VkSamplerMipmapMode</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-addressModeU-parameter",\r
+ "text": " <code>addressModeU</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerAddressMode\">VkSamplerAddressMode</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-addressModeV-parameter",\r
+ "text": " <code>addressModeV</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerAddressMode\">VkSamplerAddressMode</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-addressModeW-parameter",\r
+ "text": " <code>addressModeW</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerAddressMode\">VkSamplerAddressMode</a> value"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-minFilter-01645",\r
+ "text": " If &amp;lt;&amp;lt;samplers-YCbCr-conversion,sampler Y’C<sub>B</sub>C<sub>R</sub> conversion&amp;gt;&amp;gt; is enabled and <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT</code> is not set for the format, <code>minFilter</code> and <code>magFilter</code> <strong class=\"purple\">must</strong> be equal to the sampler Y’C<sub>B</sub>C<sub>R</sub> conversion’s <code>chromaFilter</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-addressModeU-01646",\r
+ "text": " If &amp;lt;&amp;lt;samplers-YCbCr-conversion,sampler Y’C<sub>B</sub>C<sub>R</sub> conversion&amp;gt;&amp;gt; is enabled, <code>addressModeU</code>, <code>addressModeV</code>, and <code>addressModeW</code> <strong class=\"purple\">must</strong> be <code>VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE</code>, <code>anisotropyEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>, and <code>unnormalizedCoordinates</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)+(VK_EXT_sampler_filter_minmax)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-None-01647",\r
+ "text": " The sampler reduction mode <strong class=\"purple\">must</strong> be set to <code>VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT</code> if &amp;lt;&amp;lt;samplers-YCbCr-conversion,sampler Y’C<sub>B</sub>C<sub>R</sub> conversion&amp;gt;&amp;gt; is enabled"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-magFilter-01081",\r
+ "text": " If either <code>magFilter</code> or <code>minFilter</code> is <code>VK_FILTER_CUBIC_IMG</code>, <code>anisotropyEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic+VK_EXT_sampler_filter_minmax)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-magFilter-01422",\r
+ "text": " If either <code>magFilter</code> or <code>minFilter</code> is <code>VK_FILTER_CUBIC_IMG</code>, the <code>reductionMode</code> member of <a href=\"#VkSamplerReductionModeCreateInfoEXT\">VkSamplerReductionModeCreateInfoEXT</a> <strong class=\"purple\">must</strong> be <code>VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_sampler_filter_minmax)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerCreateInfo-compareEnable-01423",\r
+ "text": " If <code>compareEnable</code> is <code>VK_TRUE</code>, the <code>reductionMode</code> member of <a href=\"#VkSamplerReductionModeCreateInfoEXT\">VkSamplerReductionModeCreateInfoEXT</a> <strong class=\"purple\">must</strong> be <code>VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSamplerReductionModeCreateInfoEXT": {\r
+ "(VK_EXT_sampler_filter_minmax)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerReductionModeCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerReductionModeCreateInfoEXT-reductionMode-parameter",\r
+ "text": " <code>reductionMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerReductionModeEXT\">VkSamplerReductionModeEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroySampler": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-sampler-01082",\r
+ "text": " All submitted commands that refer to <code>sampler</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-sampler-01083",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>sampler</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-sampler-01084",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>sampler</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-sampler-parameter",\r
+ "text": " If <code>sampler</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>sampler</code> <strong class=\"purple\">must</strong> be a valid <code>VkSampler</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySampler-sampler-parent",\r
+ "text": " If <code>sampler</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSamplerYcbcrConversionInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionInfo-conversion-parameter",\r
+ "text": " <code>conversion</code> <strong class=\"purple\">must</strong> be a valid <code>VkSamplerYcbcrConversion</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateSamplerYcbcrConversion": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkCreateSamplerYcbcrConversion-None-01648",\r
+ "text": " The &amp;lt;&amp;lt;features-features-sampler-YCbCr-conversion, sampler Y’C<sub>B</sub>C<sub>R</sub> conversion feature&amp;gt;&amp;gt; <strong class=\"purple\">must</strong> be enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSamplerYcbcrConversion-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSamplerYcbcrConversion-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSamplerYcbcrConversionCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSamplerYcbcrConversion-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSamplerYcbcrConversion-pYcbcrConversion-parameter",\r
+ "text": " <code>pYcbcrConversion</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSamplerYcbcrConversion</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkSamplerYcbcrConversionCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)+!(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-format-01649",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> not be <code>VK_FORMAT_UNDEFINED</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)+(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-format-01904",\r
+ "text": " If an external format conversion is being created, <code>format</code> <strong class=\"purple\">must</strong> be <code>VK_FORMAT_UNDEFINED</code>, otherwise it <strong class=\"purple\">must</strong> not be <code>VK_FORMAT_UNDEFINED</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-format-01650",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> support <code>VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT</code> or <code>VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-xChromaOffset-01651",\r
+ "text": " If the format does not support <code>VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT</code>, <code>xChromaOffset</code> and <code>yChromaOffset</code> <strong class=\"purple\">must</strong> not be <code>VK_CHROMA_LOCATION_COSITED_EVEN</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-xChromaOffset-01652",\r
+ "text": " If the format does not support <code>VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT</code>, <code>xChromaOffset</code> and <code>yChromaOffset</code> <strong class=\"purple\">must</strong> not be <code>VK_CHROMA_LOCATION_MIDPOINT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-format-01653",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> represent unsigned normalized values (i.e. the format must be a <code>UNORM</code> format)"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-None-01654",\r
+ "text": " If the format has a <code>_422</code> or <code>_420</code> suffix:"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-ycbcrModel-01655",\r
+ "text": " If <code>ycbcrModel</code> is not <code>VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY</code>, then <code>components.r</code>, <code>components.g</code>, and <code>components.b</code> <strong class=\"purple\">must</strong> correspond to channels of the <code>format</code>; that is, <code>components.r</code>, <code>components.g</code>, and <code>components.b</code> <strong class=\"purple\">must</strong> not be <code>VK_COMPONENT_SWIZZLE_ZERO</code> or <code>VK_COMPONENT_SWIZZLE_ONE</code>, and <strong class=\"purple\">must</strong> not correspond to a channel which contains zero or one as a consequence of &amp;lt;&amp;lt;textures-conversion-to-rgba,conversion to RGBA&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-forceExplicitReconstruction-01656",\r
+ "text": " If the format does not support <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT</code>, <code>forceExplicitReconstruction</code> <strong class=\"purple\">must</strong> be FALSE"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-chromaFilter-01657",\r
+ "text": " If the format does not support <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT</code>, <code>chromaFilter</code> <strong class=\"purple\">must</strong> be <code>VK_FILTER_NEAREST</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkExternalFormatANDROID\">VkExternalFormatANDROID</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-ycbcrModel-parameter",\r
+ "text": " <code>ycbcrModel</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerYcbcrModelConversion\">VkSamplerYcbcrModelConversion</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-ycbcrRange-parameter",\r
+ "text": " <code>ycbcrRange</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSamplerYcbcrRange\">VkSamplerYcbcrRange</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-components-parameter",\r
+ "text": " <code>components</code> <strong class=\"purple\">must</strong> be a valid <code>VkComponentMapping</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-xChromaOffset-parameter",\r
+ "text": " <code>xChromaOffset</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkChromaLocation\">VkChromaLocation</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-yChromaOffset-parameter",\r
+ "text": " <code>yChromaOffset</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkChromaLocation\">VkChromaLocation</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionCreateInfo-chromaFilter-parameter",\r
+ "text": " <code>chromaFilter</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFilter\">VkFilter</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroySamplerYcbcrConversion": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkDestroySamplerYcbcrConversion-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySamplerYcbcrConversion-ycbcrConversion-parameter",\r
+ "text": " If <code>ycbcrConversion</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>ycbcrConversion</code> <strong class=\"purple\">must</strong> be a valid <code>VkSamplerYcbcrConversion</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySamplerYcbcrConversion-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySamplerYcbcrConversion-ycbcrConversion-parent",\r
+ "text": " If <code>ycbcrConversion</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDescriptorSetLayout": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorSetLayout-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorSetLayout-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDescriptorSetLayoutCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorSetLayout-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorSetLayout-pSetLayout-parameter",\r
+ "text": " <code>pSetLayout</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDescriptorSetLayout</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetLayoutCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-binding-00279",\r
+ "text": " The <a href=\"#VkDescriptorSetLayoutBinding\">VkDescriptorSetLayoutBinding</a>::<code>binding</code> members of the elements of the <code>pBindings</code> array <strong class=\"purple\">must</strong> each have different values."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDescriptorSetLayoutBindingFlagsCreateInfoEXT\">VkDescriptorSetLayoutBindingFlagsCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDescriptorSetLayoutCreateFlagBits\">VkDescriptorSetLayoutCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-pBindings-parameter",\r
+ "text": " If <code>bindingCount</code> is not <code>0</code>, <code>pBindings</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindingCount</code> valid <code>VkDescriptorSetLayoutBinding</code> structures"\r
+ }\r
+ ],\r
+ "(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-flags-00280",\r
+ "text": " If <code>flags</code> contains <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code>, then all elements of <code>pBindings</code> <strong class=\"purple\">must</strong> not have a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-flags-00281",\r
+ "text": " If <code>flags</code> contains <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code>, then the total number of elements of all bindings <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDevicePushDescriptorPropertiesKHR\">VkPhysicalDevicePushDescriptorPropertiesKHR</a>::<code>maxPushDescriptors</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-flags-03000",\r
+ "text": " If any binding has the <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code> bit set, <code>flags</code> <strong class=\"purple\">must</strong> include <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutCreateInfo-descriptorType-03001",\r
+ "text": " If any binding has the <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code> bit set, then all bindings <strong class=\"purple\">must</strong> not have <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetLayoutBinding": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBinding-descriptorType-00282",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> or <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, and <code>descriptorCount</code> is not <code>0</code> and <code>pImmutableSamplers</code> is not <code>NULL</code>, <code>pImmutableSamplers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorCount</code> valid <code>VkSampler</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBinding-descriptorCount-00283",\r
+ "text": " If <code>descriptorCount</code> is not <code>0</code>, <code>stageFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkShaderStageFlagBits\">VkShaderStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBinding-descriptorType-01510",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> and <code>descriptorCount</code> is not <code>0</code>, then <code>stageFlags</code> <strong class=\"purple\">must</strong> be <code>0</code> or <code>VK_SHADER_STAGE_FRAGMENT_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBinding-descriptorType-parameter",\r
+ "text": " <code>descriptorType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDescriptorType\">VkDescriptorType</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetLayoutBindingFlagsCreateInfoEXT": {\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-bindingCount-03002",\r
+ "text": " If <code>bindingCount</code> is not zero, <code>bindingCount</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkDescriptorSetLayoutCreateInfo\">VkDescriptorSetLayoutCreateInfo</a>::<code>bindingCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-pBindingFlags-03004",\r
+ "text": " If an element of <code>pBindingFlags</code> includes <code>VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT</code>, then all other elements of <a href=\"#VkDescriptorSetLayoutCreateInfo\">VkDescriptorSetLayoutCreateInfo</a>::<code>pBindings</code> <strong class=\"purple\">must</strong> have a smaller value of <code>binding</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingUniformBufferUpdateAfterBind-03005",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingUniformBufferUpdateAfterBind</code> is not enabled, all bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingSampledImageUpdateAfterBind-03006",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingSampledImageUpdateAfterBind</code> is not enabled, all bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, or <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingStorageImageUpdateAfterBind-03007",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingStorageImageUpdateAfterBind</code> is not enabled, all bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingStorageBufferUpdateAfterBind-03008",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingStorageBufferUpdateAfterBind</code> is not enabled, all bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingUniformTexelBufferUpdateAfterBind-03009",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingUniformTexelBufferUpdateAfterBind</code> is not enabled, all bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingStorageTexelBufferUpdateAfterBind-03010",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingStorageTexelBufferUpdateAfterBind</code> is not enabled, all bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-None-03011",\r
+ "text": " All bindings with descriptor type <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code>, <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code>, or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> <strong class=\"purple\">must</strong> not use <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingUpdateUnusedWhilePending-03012",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingUpdateUnusedWhilePending</code> is not enabled, all elements of <code>pBindingFlags</code> <strong class=\"purple\">must</strong> not include <code>VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingPartiallyBound-03013",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingPartiallyBound</code> is not enabled, all elements of <code>pBindingFlags</code> <strong class=\"purple\">must</strong> not include <code>VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-descriptorBindingVariableDescriptorCount-03014",\r
+ "text": " If <a href=\"#VkPhysicalDeviceDescriptorIndexingFeaturesEXT\">VkPhysicalDeviceDescriptorIndexingFeaturesEXT</a>::<code>descriptorBindingVariableDescriptorCount</code> is not enabled, all elements of <code>pBindingFlags</code> <strong class=\"purple\">must</strong> not include <code>VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-pBindingFlags-03015",\r
+ "text": " If an element of <code>pBindingFlags</code> includes <code>VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT</code>, that element’s <code>descriptorType</code> <strong class=\"purple\">must</strong> not be <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_BINDING_FLAGS_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-pBindingFlags-parameter",\r
+ "text": " If <code>bindingCount</code> is not <code>0</code>, <code>pBindingFlags</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindingCount</code> valid combinations of <a href=\"#VkDescriptorBindingFlagBitsEXT\">VkDescriptorBindingFlagBitsEXT</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-pBindingFlags-requiredbitmask",\r
+ "text": " Each element of <code>pBindingFlags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)+(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutBindingFlagsCreateInfoEXT-flags-03003",\r
+ "text": " If <a href=\"#VkDescriptorSetLayoutCreateInfo\">VkDescriptorSetLayoutCreateInfo</a>::<code>flags</code> includes <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code>, then all elements of <code>pBindingFlags</code> <strong class=\"purple\">must</strong> not include <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code>, <code>VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT</code>, or <code>VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDescriptorSetLayoutSupport": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance3)": [\r
+ {\r
+ "vuid": "VUID-vkGetDescriptorSetLayoutSupport-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDescriptorSetLayoutSupport-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDescriptorSetLayoutCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDescriptorSetLayoutSupport-pSupport-parameter",\r
+ "text": " <code>pSupport</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDescriptorSetLayoutSupport</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetLayoutSupport": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance3)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutSupport-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetLayoutSupport-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDescriptorSetVariableDescriptorCountLayoutSupportEXT\">VkDescriptorSetVariableDescriptorCountLayoutSupportEXT</a>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetVariableDescriptorCountLayoutSupportEXT": {\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetVariableDescriptorCountLayoutSupportEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_LAYOUT_SUPPORT_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyDescriptorSetLayout": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorSetLayout-descriptorSetLayout-00284",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>descriptorSetLayout</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorSetLayout-descriptorSetLayout-00285",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>descriptorSetLayout</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorSetLayout-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorSetLayout-descriptorSetLayout-parameter",\r
+ "text": " If <code>descriptorSetLayout</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>descriptorSetLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSetLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorSetLayout-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorSetLayout-descriptorSetLayout-parent",\r
+ "text": " If <code>descriptorSetLayout</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreatePipelineLayout": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineLayout-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineLayout-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPipelineLayoutCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineLayout-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreatePipelineLayout-pPipelineLayout-parameter",\r
+ "text": " <code>pPipelineLayout</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPipelineLayout</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineLayoutCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-setLayoutCount-00286",\r
+ "text": " <code>setLayoutCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxBoundDescriptorSets</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pPushConstantRanges-00292",\r
+ "text": " Any two elements of <code>pPushConstantRanges</code> <strong class=\"purple\">must</strong> not include the same stage in <code>stageFlags</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-parameter",\r
+ "text": " If <code>setLayoutCount</code> is not <code>0</code>, <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>setLayoutCount</code> valid <code>VkDescriptorSetLayout</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pPushConstantRanges-parameter",\r
+ "text": " If <code>pushConstantRangeCount</code> is not <code>0</code>, <code>pPushConstantRanges</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pushConstantRangeCount</code> valid <code>VkPushConstantRange</code> structures"\r
+ }\r
+ ],\r
+ "!(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-00287",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> and <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code> accessible to any shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorSamplers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-00288",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> and <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> accessible to any shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorUniformBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-00289",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> and <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> accessible to any shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorStorageBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-00290",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> accessible to any shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorSampledImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-00291",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> accessible to any shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorStorageImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01676",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorInputAttachments</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01677",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> and <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetSamplers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01678",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> accessible across all shader stagess and and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetUniformBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01679",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetUniformBuffersDynamic</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01680",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetStorageBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01681",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetStorageBuffersDynamic</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01682",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetSampledImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01683",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetStorageImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-01684",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetInputAttachments</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03016",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> and <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorSamplers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03017",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> and <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorUniformBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03018",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> and <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorStorageBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03019",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorSampledImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03020",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorStorageImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03021",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPerStageDescriptorInputAttachments</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03022",\r
+ "text": " The total number of descriptors with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> and <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxPerStageDescriptorUpdateAfterBindSamplers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03023",\r
+ "text": " The total number of descriptors with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> and <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxPerStageDescriptorUpdateAfterBindUniformBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03024",\r
+ "text": " The total number of descriptors with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> and <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxPerStageDescriptorUpdateAfterBindStorageBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03025",\r
+ "text": " The total number of descriptors with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxPerStageDescriptorUpdateAfterBindSampledImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03026",\r
+ "text": " The total number of descriptors with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxPerStageDescriptorUpdateAfterBindStorageImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03027",\r
+ "text": " The total number of descriptors with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> accessible to any given shader stage across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxPerStageDescriptorUpdateAfterBindInputAttachments</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03028",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> and <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetSamplers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03029",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> accessible across all shader stagess and and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetUniformBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03030",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetUniformBuffersDynamic</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03031",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetStorageBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03032",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetStorageBuffersDynamic</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03033",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetSampledImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03034",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetStorageImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-descriptorType-03035",\r
+ "text": " The total number of descriptors in descriptor set layouts created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set with a <code>descriptorType</code> of <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDescriptorSetInputAttachments</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03036",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> and <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindSamplers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03037",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> accessible across all shader stagess and and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindUniformBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03038",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindUniformBuffersDynamic</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03039",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindStorageBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03040",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindStorageBuffersDynamic</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03041",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindSampledImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03042",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, and <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindStorageImages</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-03043",\r
+ "text": " The total number of descriptors of the type <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code> accessible across all shader stages and across all elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceDescriptorIndexingPropertiesEXT</code>::<code>maxDescriptorSetUpdateAfterBindInputAttachments</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineLayoutCreateInfo-pSetLayouts-00293",\r
+ "text": " <code>pSetLayouts</code> <strong class=\"purple\">must</strong> not contain more than one descriptor set layout that was created with <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code> set"\r
+ }\r
+ ]\r
+ },\r
+ "VkPushConstantRange": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-offset-00294",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxPushConstantsSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-offset-00295",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-size-00296",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-size-00297",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-size-00298",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPushConstantsSize</code> minus <code>offset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-stageFlags-parameter",\r
+ "text": " <code>stageFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkShaderStageFlagBits\">VkShaderStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPushConstantRange-stageFlags-requiredbitmask",\r
+ "text": " <code>stageFlags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyPipelineLayout": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineLayout-pipelineLayout-00299",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>pipelineLayout</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineLayout-pipelineLayout-00300",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>pipelineLayout</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineLayout-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineLayout-pipelineLayout-parameter",\r
+ "text": " If <code>pipelineLayout</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>pipelineLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineLayout-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyPipelineLayout-pipelineLayout-parent",\r
+ "text": " If <code>pipelineLayout</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDescriptorPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorPool-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDescriptorPoolCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorPool-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorPool-pDescriptorPool-parameter",\r
+ "text": " <code>pDescriptorPool</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDescriptorPool</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorPoolCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolCreateInfo-maxSets-00301",\r
+ "text": " <code>maxSets</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolCreateInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDescriptorPoolCreateFlagBits\">VkDescriptorPoolCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolCreateInfo-pPoolSizes-parameter",\r
+ "text": " <code>pPoolSizes</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>poolSizeCount</code> valid <code>VkDescriptorPoolSize</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolCreateInfo-poolSizeCount-arraylength",\r
+ "text": " <code>poolSizeCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorPoolSize": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolSize-descriptorCount-00302",\r
+ "text": " <code>descriptorCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorPoolSize-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDescriptorType\">VkDescriptorType</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyDescriptorPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-descriptorPool-00303",\r
+ "text": " All submitted commands that refer to <code>descriptorPool</code> (via any allocated descriptor sets) <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-descriptorPool-00304",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>descriptorPool</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-descriptorPool-00305",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>descriptorPool</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-descriptorPool-parameter",\r
+ "text": " If <code>descriptorPool</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>descriptorPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorPool-descriptorPool-parent",\r
+ "text": " If <code>descriptorPool</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkAllocateDescriptorSets": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkAllocateDescriptorSets-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateDescriptorSets-pAllocateInfo-parameter",\r
+ "text": " <code>pAllocateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDescriptorSetAllocateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAllocateDescriptorSets-pDescriptorSets-parameter",\r
+ "text": " <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pAllocateInfo</code>::descriptorSetCount <code>VkDescriptorSet</code> handles"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetAllocateInfo": {\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-descriptorSetCount-00306",\r
+ "text": " <code>descriptorSetCount</code> <strong class=\"purple\">must</strong> not be greater than the number of sets that are currently available for allocation in <code>descriptorPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-descriptorPool-00307",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> have enough free descriptor capacity remaining to allocate the descriptor sets of the specified layouts"\r
+ }\r
+ ],\r
+ "(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-pSetLayouts-00308",\r
+ "text": " Each element of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> not have been created with <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code> set"\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-pSetLayouts-03044",\r
+ "text": " If any element of <code>pSetLayouts</code> was created with the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> bit set, <code>descriptorPool</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT</code> flag set"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDescriptorSetVariableDescriptorCountAllocateInfoEXT\">VkDescriptorSetVariableDescriptorCountAllocateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-descriptorPool-parameter",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-pSetLayouts-parameter",\r
+ "text": " <code>pSetLayouts</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorSetCount</code> valid <code>VkDescriptorSetLayout</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-descriptorSetCount-arraylength",\r
+ "text": " <code>descriptorSetCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetAllocateInfo-commonparent",\r
+ "text": " Both of <code>descriptorPool</code>, and the elements of <code>pSetLayouts</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorSetVariableDescriptorCountAllocateInfoEXT": {\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetVariableDescriptorCountAllocateInfoEXT-descriptorSetCount-03045",\r
+ "text": " If <code>descriptorSetCount</code> is not zero, <code>descriptorSetCount</code> <strong class=\"purple\">must</strong> equal <a href=\"#VkDescriptorSetAllocateInfo\">VkDescriptorSetAllocateInfo</a>::<code>descriptorSetCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetVariableDescriptorCountAllocateInfoEXT-pSetLayouts-03046",\r
+ "text": " If <a href=\"#VkDescriptorSetAllocateInfo\">VkDescriptorSetAllocateInfo</a>::<code>pSetLayouts</code>[i] has a variable descriptor count binding, then <code>pDescriptorCounts</code>[i] <strong class=\"purple\">must</strong> be less than or equal to the descriptor count specified for that binding when the descriptor set layout was created."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetVariableDescriptorCountAllocateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_ALLOCATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorSetVariableDescriptorCountAllocateInfoEXT-pDescriptorCounts-parameter",\r
+ "text": " If <code>descriptorSetCount</code> is not <code>0</code>, <code>pDescriptorCounts</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorSetCount</code> <code>uint32_t</code> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkFreeDescriptorSets": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-pDescriptorSets-00309",\r
+ "text": " All submitted commands that refer to any element of <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-pDescriptorSets-00310",\r
+ "text": " <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorSetCount</code> <code>VkDescriptorSet</code> handles, each element of which <strong class=\"purple\">must</strong> either be a valid handle or <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-pDescriptorSets-00311",\r
+ "text": " Each valid handle in <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> have been allocated from <code>descriptorPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-descriptorPool-00312",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT</code> flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-descriptorPool-parameter",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-descriptorSetCount-arraylength",\r
+ "text": " <code>descriptorSetCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-descriptorPool-parent",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkFreeDescriptorSets-pDescriptorSets-parent",\r
+ "text": " Each element of <code>pDescriptorSets</code> that is a valid handle <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>descriptorPool</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkResetDescriptorPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkResetDescriptorPool-descriptorPool-00313",\r
+ "text": " All uses of <code>descriptorPool</code> (via any allocated descriptor sets) <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetDescriptorPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetDescriptorPool-descriptorPool-parameter",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetDescriptorPool-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkResetDescriptorPool-descriptorPool-parent",\r
+ "text": " <code>descriptorPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkUpdateDescriptorSets": {\r
+ "!(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSets-dstSet-00314",\r
+ "text": " The <code>dstSet</code> member of each element of <code>pDescriptorWrites</code> or <code>pDescriptorCopies</code> <strong class=\"purple\">must</strong> not be used by any command that was recorded to a command buffer which is in the &amp;lt;&amp;lt;commandbuffers-lifecycle, pending state&amp;gt;&amp;gt;."\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSets-None-03047",\r
+ "text": " Descriptor bindings updated by this command which were created without the <code>VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT</code> or <code>VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT</code> bits set <strong class=\"purple\">must</strong> not be used by any command that was recorded to a command buffer which is in the &amp;lt;&amp;lt;commandbuffers-lifecycle,pending state&amp;gt;&amp;gt;."\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSets-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSets-pDescriptorWrites-parameter",\r
+ "text": " If <code>descriptorWriteCount</code> is not <code>0</code>, <code>pDescriptorWrites</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorWriteCount</code> valid <code>VkWriteDescriptorSet</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSets-pDescriptorCopies-parameter",\r
+ "text": " If <code>descriptorCopyCount</code> is not <code>0</code>, <code>pDescriptorCopies</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorCopyCount</code> valid <code>VkCopyDescriptorSet</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkWriteDescriptorSet": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-dstBinding-00315",\r
+ "text": " <code>dstBinding</code> <strong class=\"purple\">must</strong> be less than or equal to the maximum value of <code>binding</code> of all <a href=\"#VkDescriptorSetLayoutBinding\">VkDescriptorSetLayoutBinding</a> structures specified when <code>dstSet</code>’s descriptor set layout was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-dstBinding-00316",\r
+ "text": " <code>dstBinding</code> <strong class=\"purple\">must</strong> be a binding with a non-zero <code>descriptorCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorCount-00317",\r
+ "text": " All consecutive bindings updated via a single <code>VkWriteDescriptorSet</code> structure, except those with a <code>descriptorCount</code> of zero, <strong class=\"purple\">must</strong> have identical <code>descriptorType</code> and <code>stageFlags</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorCount-00318",\r
+ "text": " All consecutive bindings updated via a single <code>VkWriteDescriptorSet</code> structure, except those with a <code>descriptorCount</code> of zero, <strong class=\"purple\">must</strong> all either use immutable samplers or <strong class=\"purple\">must</strong> all not use immutable samplers."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00319",\r
+ "text": " <code>descriptorType</code> <strong class=\"purple\">must</strong> match the type of <code>dstBinding</code> within <code>dstSet</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-dstSet-00320",\r
+ "text": " <code>dstSet</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDescriptorSet\">VkDescriptorSet</a> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-dstArrayElement-00321",\r
+ "text": " The sum of <code>dstArrayElement</code> and <code>descriptorCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of array elements in the descriptor set binding specified by <code>dstBinding</code>, and all applicable consecutive bindings, as described by &amp;lt;&amp;lt;descriptorsets-updates-consecutive&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00322",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, or <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code>, <code>pImageInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorCount</code> valid <code>VkDescriptorImageInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00323",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code>, <code>pTexelBufferView</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorCount</code> valid <code>VkBufferView</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00324",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code>, <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code>, <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code>, or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>, <code>pBufferInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorCount</code> valid <code>VkDescriptorBufferInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00325",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_SAMPLER</code> or <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, and <code>dstSet</code> was not allocated with a layout that included immutable samplers for <code>dstBinding</code> with <code>descriptorType</code>, the <code>sampler</code> member of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkSampler</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00326",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code>, <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, or <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code>, the <code>imageView</code> and <code>imageLayout</code> members of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageView</code> and <a href=\"#VkImageLayout\">VkImageLayout</a>, respectively"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-01402",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, for each descriptor that will be accessed via load or store operations the <code>imageLayout</code> member for corresponding elements of <code>pImageInfo</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00327",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code>, the <code>offset</code> member of each element of <code>pBufferInfo</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minUniformBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00328",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>, the <code>offset</code> member of each element of <code>pBufferInfo</code> <strong class=\"purple\">must</strong> be a multiple of <code>VkPhysicalDeviceLimits</code>::<code>minStorageBufferOffsetAlignment</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00329",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code>, <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code>, <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code>, or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>, and the <code>buffer</code> member of any element of <code>pBufferInfo</code> is the handle of a non-sparse buffer, then that buffer <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00330",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code>, the <code>buffer</code> member of each element of <code>pBufferInfo</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00331",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>, the <code>buffer</code> member of each element of <code>pBufferInfo</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_STORAGE_BUFFER_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00332",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC</code>, the <code>range</code> member of each element of <code>pBufferInfo</code>, or the effective range if <code>range</code> is <code>VK_WHOLE_SIZE</code>, <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxUniformBufferRange</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00333",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER</code> or <code>VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC</code>, the <code>range</code> member of each element of <code>pBufferInfo</code>, or the effective range if <code>range</code> is <code>VK_WHOLE_SIZE</code>, <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxStorageBufferRange</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00334",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER</code>, the <code>VkBuffer</code> that each element of <code>pTexelBufferView</code> was created from <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00335",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER</code>, the <code>VkBuffer</code> that each element of <code>pTexelBufferView</code> was created from <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00336",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code> or <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code>, the <code>imageView</code> member of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> have been created with the identity swizzle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00337",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code> or <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, the <code>imageView</code> member of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_SAMPLED_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-01403",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE</code> or <code>VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER</code>, the <code>imageLayout</code> member of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00338",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT</code>, the <code>imageView</code> member of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-00339",\r
+ "text": " If <code>descriptorType</code> is <code>VK_DESCRIPTOR_TYPE_STORAGE_IMAGE</code>, the <code>imageView</code> member of each element of <code>pImageInfo</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_STORAGE_BIT</code> set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorType-parameter",\r
+ "text": " <code>descriptorType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDescriptorType\">VkDescriptorType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorCount-arraylength",\r
+ "text": " <code>descriptorCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-commonparent",\r
+ "text": " Both of <code>dstSet</code>, and the elements of <code>pTexelBufferView</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkWriteDescriptorSet-descriptorCount-03048",\r
+ "text": " All consecutive bindings updated via a single <code>VkWriteDescriptorSet</code> structure, except those with a <code>descriptorCount</code> of zero, <strong class=\"purple\">must</strong> have identical <a href=\"#VkDescriptorBindingFlagBitsEXT\">VkDescriptorBindingFlagBitsEXT</a>."\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorBufferInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorBufferInfo-offset-00340",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorBufferInfo-range-00341",\r
+ "text": " If <code>range</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>range</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorBufferInfo-range-00342",\r
+ "text": " If <code>range</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>range</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code> minus <code>offset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorBufferInfo-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorImageInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorImageInfo-imageView-00343",\r
+ "text": " <code>imageView</code> <strong class=\"purple\">must</strong> not be 2D or 2D array image view created from a 3D image"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorImageInfo-imageLayout-00344",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> match the actual <a href=\"#VkImageLayout\">VkImageLayout</a> of each subresource accessible from <code>imageView</code> at the time this descriptor is accessed"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorImageInfo-commonparent",\r
+ "text": " Both of <code>imageView</code>, and <code>sampler</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorImageInfo-sampler-01563",\r
+ "text": " If <code>sampler</code> is used and enables &amp;lt;&amp;lt;samplers-YCbCr-conversion,sampler Y’C<sub>B</sub>C<sub>R</sub> conversion&amp;gt;&amp;gt;:"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorImageInfo-sampler-01564",\r
+ "text": " If <code>sampler</code> is used and does not enable &amp;lt;&amp;lt;samplers-YCbCr-conversion, sampler Y’C<sub>B</sub>C<sub>R</sub> conversion&amp;gt;&amp;gt; and the <a href=\"#VkFormat\">VkFormat</a> of the image is a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt;, the image <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT</code>, and the <code>aspectMask</code> of the <code>imageView</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code> or (for three-plane formats only) <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkCopyDescriptorSet": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcBinding-00345",\r
+ "text": " <code>srcBinding</code> <strong class=\"purple\">must</strong> be a valid binding within <code>srcSet</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcArrayElement-00346",\r
+ "text": " The sum of <code>srcArrayElement</code> and <code>descriptorCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of array elements in the descriptor set binding specified by <code>srcBinding</code>, and all applicable consecutive bindings, as described by &amp;lt;&amp;lt;descriptorsets-updates-consecutive&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-dstBinding-00347",\r
+ "text": " <code>dstBinding</code> <strong class=\"purple\">must</strong> be a valid binding within <code>dstSet</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-dstArrayElement-00348",\r
+ "text": " The sum of <code>dstArrayElement</code> and <code>descriptorCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of array elements in the descriptor set binding specified by <code>dstBinding</code>, and all applicable consecutive bindings, as described by &amp;lt;&amp;lt;descriptorsets-updates-consecutive&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcSet-00349",\r
+ "text": " If <code>srcSet</code> is equal to <code>dstSet</code>, then the source and destination ranges of descriptors <strong class=\"purple\">must</strong> not overlap, where the ranges <strong class=\"purple\">may</strong> include array elements from consecutive bindings as described by &amp;lt;&amp;lt;descriptorsets-updates-consecutive&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcSet-parameter",\r
+ "text": " <code>srcSet</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSet</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-dstSet-parameter",\r
+ "text": " <code>dstSet</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSet</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-commonparent",\r
+ "text": " Both of <code>dstSet</code>, and <code>srcSet</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcSet-01918",\r
+ "text": " If <code>srcSet</code>’s layout was created with the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> flag set, then <code>dstSet</code>’s layout <strong class=\"purple\">must</strong> also have been created with the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> flag set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcSet-01919",\r
+ "text": " If <code>srcSet</code>’s layout was created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> flag set, then <code>dstSet</code>’s layout <strong class=\"purple\">must</strong> also have been created without the <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT</code> flag set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcSet-01920",\r
+ "text": " If the descriptor pool from which <code>srcSet</code> was allocated was created with the <code>VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT</code> flag set, then the descriptor pool from which <code>dstSet</code> was allocated <strong class=\"purple\">must</strong> also have been created with the <code>VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT</code> flag set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCopyDescriptorSet-srcSet-01921",\r
+ "text": " If the descriptor pool from which <code>srcSet</code> was allocated was created without the <code>VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT</code> flag set, then the descriptor pool from which <code>dstSet</code> was allocated <strong class=\"purple\">must</strong> also have been created without the <code>VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT</code> flag set"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDescriptorUpdateTemplate": {\r
+ "(VK_VERSION_1_1,VK_KHR_descriptor_update_template)": [\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorUpdateTemplate-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorUpdateTemplate-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDescriptorUpdateTemplateCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorUpdateTemplate-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDescriptorUpdateTemplate-pDescriptorUpdateTemplate-parameter",\r
+ "text": " <code>pDescriptorUpdateTemplate</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDescriptorUpdateTemplate</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorUpdateTemplateCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_descriptor_update_template)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-templateType-00350",\r
+ "text": " If <code>templateType</code> is <code>VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET</code>, <code>descriptorSetLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSetLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-pDescriptorUpdateEntries-parameter",\r
+ "text": " <code>pDescriptorUpdateEntries</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorUpdateEntryCount</code> valid <code>VkDescriptorUpdateTemplateEntry</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-templateType-parameter",\r
+ "text": " <code>templateType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDescriptorUpdateTemplateType\">VkDescriptorUpdateTemplateType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-descriptorSetLayout-parameter",\r
+ "text": " If <code>descriptorSetLayout</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>descriptorSetLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSetLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-descriptorUpdateEntryCount-arraylength",\r
+ "text": " <code>descriptorUpdateEntryCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-commonparent",\r
+ "text": " Both of <code>descriptorSetLayout</code>, and <code>pipelineLayout</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_descriptor_update_template)+(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-templateType-00351",\r
+ "text": " If <code>templateType</code> is <code>VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR</code>, <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineBindPoint\">VkPipelineBindPoint</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-templateType-00352",\r
+ "text": " If <code>templateType</code> is <code>VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR</code>, <code>pipelineLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateCreateInfo-templateType-00353",\r
+ "text": " If <code>templateType</code> is <code>VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR</code>, <code>set</code> <strong class=\"purple\">must</strong> be the unique set number in the pipeline layout that uses a descriptor set layout that was created with <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDescriptorUpdateTemplateEntry": {\r
+ "(VK_VERSION_1_1,VK_KHR_descriptor_update_template)": [\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateEntry-dstBinding-00354",\r
+ "text": " <code>dstBinding</code> <strong class=\"purple\">must</strong> be a valid binding in the descriptor set layout implicitly specified when using a descriptor update template to update descriptors."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateEntry-dstArrayElement-00355",\r
+ "text": " <code>dstArrayElement</code> and <code>descriptorCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of array elements in the descriptor set binding implicitly specified when using a descriptor update template to update descriptors, and all applicable consecutive bindings, as described by &amp;lt;&amp;lt;descriptorsets-updates-consecutive&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDescriptorUpdateTemplateEntry-descriptorType-parameter",\r
+ "text": " <code>descriptorType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDescriptorType\">VkDescriptorType</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyDescriptorUpdateTemplate": {\r
+ "(VK_VERSION_1_1,VK_KHR_descriptor_update_template)": [\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorUpdateTemplate-descriptorSetLayout-00356",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>descriptorSetLayout</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorUpdateTemplate-descriptorSetLayout-00357",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>descriptorSetLayout</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorUpdateTemplate-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorUpdateTemplate-descriptorUpdateTemplate-parameter",\r
+ "text": " If <code>descriptorUpdateTemplate</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>descriptorUpdateTemplate</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorUpdateTemplate</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorUpdateTemplate-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDescriptorUpdateTemplate-descriptorUpdateTemplate-parent",\r
+ "text": " If <code>descriptorUpdateTemplate</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkUpdateDescriptorSetWithTemplate": {\r
+ "(VK_VERSION_1_1,VK_KHR_descriptor_update_template)": [\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSetWithTemplate-pData-01685",\r
+ "text": " <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to a memory that contains one or more valid instances of <a href=\"#VkDescriptorImageInfo\">VkDescriptorImageInfo</a>, <a href=\"#VkDescriptorBufferInfo\">VkDescriptorBufferInfo</a>, or <a href=\"#VkBufferView\">VkBufferView</a> in a layout defined by <code>descriptorUpdateTemplate</code> when it was created with <a href=\"#vkCreateDescriptorUpdateTemplate\">vkCreateDescriptorUpdateTemplate</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSetWithTemplate-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSetWithTemplate-descriptorSet-parameter",\r
+ "text": " <code>descriptorSet</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSet</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSetWithTemplate-descriptorUpdateTemplate-parameter",\r
+ "text": " <code>descriptorUpdateTemplate</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorUpdateTemplate</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUpdateDescriptorSetWithTemplate-descriptorUpdateTemplate-parent",\r
+ "text": " <code>descriptorUpdateTemplate</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBindDescriptorSets": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-pDescriptorSets-00358",\r
+ "text": " Each element of <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> have been allocated with a <code>VkDescriptorSetLayout</code> that matches (is the same as, or identically defined as) the <code>VkDescriptorSetLayout</code> at set <em>n</em> in <code>layout</code>, where <em>n</em> is the sum of <code>firstSet</code> and the index into <code>pDescriptorSets</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-dynamicOffsetCount-00359",\r
+ "text": " <code>dynamicOffsetCount</code> <strong class=\"purple\">must</strong> be equal to the total number of dynamic descriptors in <code>pDescriptorSets</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-firstSet-00360",\r
+ "text": " The sum of <code>firstSet</code> and <code>descriptorSetCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPipelineLayoutCreateInfo</code>::<code>setLayoutCount</code> provided when <code>layout</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-pipelineBindPoint-00361",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be supported by the <code>commandBuffer</code>’s parent <code>VkCommandPool</code>’s queue family"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-pDynamicOffsets-00362",\r
+ "text": " Each element of <code>pDynamicOffsets</code> <strong class=\"purple\">must</strong> satisfy the required alignment for the corresponding descriptor binding’s descriptor type"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-pipelineBindPoint-parameter",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineBindPoint\">VkPipelineBindPoint</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-pDescriptorSets-parameter",\r
+ "text": " <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorSetCount</code> valid <code>VkDescriptorSet</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-pDynamicOffsets-parameter",\r
+ "text": " If <code>dynamicOffsetCount</code> is not <code>0</code>, <code>pDynamicOffsets</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dynamicOffsetCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-descriptorSetCount-arraylength",\r
+ "text": " <code>descriptorSetCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindDescriptorSets-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>layout</code>, and the elements of <code>pDescriptorSets</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdPushDescriptorSetKHR": {\r
+ "(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-pipelineBindPoint-00363",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be supported by the <code>commandBuffer</code>’s parent <code>VkCommandPool</code>’s queue family"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-set-00364",\r
+ "text": " <code>set</code> <strong class=\"purple\">must</strong> be less than <code>VkPipelineLayoutCreateInfo</code>::<code>setLayoutCount</code> provided when <code>layout</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-set-00365",\r
+ "text": " <code>set</code> <strong class=\"purple\">must</strong> be the unique set number in the pipeline layout that uses a descriptor set layout that was created with <code>VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-pipelineBindPoint-parameter",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineBindPoint\">VkPipelineBindPoint</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-pDescriptorWrites-parameter",\r
+ "text": " <code>pDescriptorWrites</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>descriptorWriteCount</code> valid <code>VkWriteDescriptorSet</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-descriptorWriteCount-arraylength",\r
+ "text": " <code>descriptorWriteCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetKHR-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>layout</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdPushDescriptorSetWithTemplateKHR": {\r
+ "(VK_KHR_push_descriptor)+(VK_VERSION_1_1,VK_KHR_descriptor_update_template)": [\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-commandBuffer-00366",\r
+ "text": " The pipelineBindPoint specified during the creation of the descriptor update template <strong class=\"purple\">must</strong> be supported by the <code>commandBuffer</code>’s parent <code>VkCommandPool</code>’s queue family"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-pData-01686",\r
+ "text": " <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to a memory that contains one or more valid instances of <a href=\"#VkDescriptorImageInfo\">VkDescriptorImageInfo</a>, <a href=\"#VkDescriptorBufferInfo\">VkDescriptorBufferInfo</a>, or <a href=\"#VkBufferView\">VkBufferView</a> in a layout defined by <code>descriptorUpdateTemplate</code> when it was created with <a href=\"#vkCreateDescriptorUpdateTemplateKHR\">vkCreateDescriptorUpdateTemplateKHR</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-descriptorUpdateTemplate-parameter",\r
+ "text": " <code>descriptorUpdateTemplate</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorUpdateTemplate</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushDescriptorSetWithTemplateKHR-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>descriptorUpdateTemplate</code>, and <code>layout</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdPushConstants": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-offset-01795",\r
+ "text": " For each byte in the range specified by <code>offset</code> and <code>size</code> and for each shader stage in <code>stageFlags</code>, there <strong class=\"purple\">must</strong> be a push constant range in <code>layout</code> that includes that byte and that stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-offset-01796",\r
+ "text": " For each byte in the range specified by <code>offset</code> and <code>size</code> and for each push constant range that overlaps that byte, <code>stageFlags</code> <strong class=\"purple\">must</strong> include all stages in that push constant range’s <a href=\"#VkPushConstantRange\">VkPushConstantRange</a>::<code>stageFlags</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-offset-00368",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-size-00369",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-offset-00370",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxPushConstantsSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-size-00371",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxPushConstantsSize</code> minus <code>offset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-layout-parameter",\r
+ "text": " <code>layout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-stageFlags-parameter",\r
+ "text": " <code>stageFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkShaderStageFlagBits\">VkShaderStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-stageFlags-requiredbitmask",\r
+ "text": " <code>stageFlags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-pValues-parameter",\r
+ "text": " <code>pValues</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>size</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-size-arraylength",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdPushConstants-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>layout</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateQueryPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCreateQueryPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateQueryPool-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkQueryPoolCreateInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateQueryPool-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateQueryPool-pQueryPool-parameter",\r
+ "text": " <code>pQueryPool</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkQueryPool</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkQueryPoolCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkQueryPoolCreateInfo-queryType-00791",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-pipelineStatisticsQuery,pipeline statistics queries&amp;gt;&amp;gt; feature is not enabled, <code>queryType</code> <strong class=\"purple\">must</strong> not be <code>VK_QUERY_TYPE_PIPELINE_STATISTICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkQueryPoolCreateInfo-queryType-00792",\r
+ "text": " If <code>queryType</code> is <code>VK_QUERY_TYPE_PIPELINE_STATISTICS</code>, <code>pipelineStatistics</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkQueryPipelineStatisticFlagBits\">VkQueryPipelineStatisticFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkQueryPoolCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkQueryPoolCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkQueryPoolCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkQueryPoolCreateInfo-queryType-parameter",\r
+ "text": " <code>queryType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkQueryType\">VkQueryType</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyQueryPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-queryPool-00793",\r
+ "text": " All submitted commands that refer to <code>queryPool</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-queryPool-00794",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>queryPool</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-queryPool-00795",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>queryPool</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-queryPool-parameter",\r
+ "text": " If <code>queryPool</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyQueryPool-queryPool-parent",\r
+ "text": " If <code>queryPool</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdResetQueryPool": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-firstQuery-00796",\r
+ "text": " <code>firstQuery</code> <strong class=\"purple\">must</strong> be less than the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-firstQuery-00797",\r
+ "text": " The sum of <code>firstQuery</code> and <code>queryCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-queryPool-parameter",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResetQueryPool-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>queryPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBeginQuery": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-queryPool-01922",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> have been created with a <code>queryType</code> that differs from that of any queries that are &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt; within <code>commandBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-None-00807",\r
+ "text": " All queries used by the command <strong class=\"purple\">must</strong> be unavailable"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-queryType-00800",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-occlusionQueryPrecise,precise occlusion queries&amp;gt;&amp;gt; feature is not enabled, or the <code>queryType</code> used to create <code>queryPool</code> was not <code>VK_QUERY_TYPE_OCCLUSION</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_QUERY_CONTROL_PRECISE_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-query-00802",\r
+ "text": " <code>query</code> <strong class=\"purple\">must</strong> be less than the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-queryType-00803",\r
+ "text": " If the <code>queryType</code> used to create <code>queryPool</code> was <code>VK_QUERY_TYPE_OCCLUSION</code>, the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-queryType-00804",\r
+ "text": " If the <code>queryType</code> used to create <code>queryPool</code> was <code>VK_QUERY_TYPE_PIPELINE_STATISTICS</code> and any of the <code>pipelineStatistics</code> indicate graphics operations, the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-queryType-00805",\r
+ "text": " If the <code>queryType</code> used to create <code>queryPool</code> was <code>VK_QUERY_TYPE_PIPELINE_STATISTICS</code> and any of the <code>pipelineStatistics</code> indicate compute operations, the <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-queryPool-parameter",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkQueryControlFlagBits\">VkQueryControlFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>queryPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-commandBuffer-01885",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> not be a protected command buffer"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginQuery-query-00808",\r
+ "text": " If <code>vkCmdBeginQuery</code> is called within a render pass instance, the sum of <code>query</code> and the number of bits set in the current subpass’s view mask <strong class=\"purple\">must</strong> be less than or equal to the number of queries in <code>queryPool</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdEndQuery": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-None-01923",\r
+ "text": " All queries used by the command <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;queries-operation-active,active&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-query-00810",\r
+ "text": " <code>query</code> <strong class=\"purple\">must</strong> be less than the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-queryPool-parameter",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>queryPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-commandBuffer-01886",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> not be a protected command buffer"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdEndQuery-query-00812",\r
+ "text": " If <code>vkCmdEndQuery</code> is called within a render pass instance, the sum of <code>query</code> and the number of bits set in the current subpass’s view mask <strong class=\"purple\">must</strong> be less than or equal to the number of queries in <code>queryPool</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetQueryPoolResults": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-firstQuery-00813",\r
+ "text": " <code>firstQuery</code> <strong class=\"purple\">must</strong> be less than the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-flags-00814",\r
+ "text": " If <code>VK_QUERY_RESULT_64_BIT</code> is not set in <code>flags</code> then <code>pData</code> and <code>stride</code> <strong class=\"purple\">must</strong> be multiples of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-flags-00815",\r
+ "text": " If <code>VK_QUERY_RESULT_64_BIT</code> is set in <code>flags</code> then <code>pData</code> and <code>stride</code> <strong class=\"purple\">must</strong> be multiples of <code>8</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-firstQuery-00816",\r
+ "text": " The sum of <code>firstQuery</code> and <code>queryCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-dataSize-00817",\r
+ "text": " <code>dataSize</code> <strong class=\"purple\">must</strong> be large enough to contain the result of each query, as described &amp;lt;&amp;lt;queries-operation-memorylayout,here&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-queryType-00818",\r
+ "text": " If the <code>queryType</code> used to create <code>queryPool</code> was <code>VK_QUERY_TYPE_TIMESTAMP</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_QUERY_RESULT_PARTIAL_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-queryPool-parameter",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-pData-parameter",\r
+ "text": " <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dataSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkQueryResultFlagBits\">VkQueryResultFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-dataSize-arraylength",\r
+ "text": " <code>dataSize</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetQueryPoolResults-queryPool-parent",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdCopyQueryPoolResults": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-dstOffset-00819",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>dstBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-firstQuery-00820",\r
+ "text": " <code>firstQuery</code> <strong class=\"purple\">must</strong> be less than the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-firstQuery-00821",\r
+ "text": " The sum of <code>firstQuery</code> and <code>queryCount</code> <strong class=\"purple\">must</strong> be less than or equal to the number of queries in <code>queryPool</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-flags-00822",\r
+ "text": " If <code>VK_QUERY_RESULT_64_BIT</code> is not set in <code>flags</code> then <code>dstOffset</code> and <code>stride</code> <strong class=\"purple\">must</strong> be multiples of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-flags-00823",\r
+ "text": " If <code>VK_QUERY_RESULT_64_BIT</code> is set in <code>flags</code> then <code>dstOffset</code> and <code>stride</code> <strong class=\"purple\">must</strong> be multiples of <code>8</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-dstBuffer-00824",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have enough storage, from <code>dstOffset</code>, to contain the result of each query, as described &amp;lt;&amp;lt;queries-operation-memorylayout,here&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-dstBuffer-00825",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-dstBuffer-00826",\r
+ "text": " If <code>dstBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-queryType-00827",\r
+ "text": " If the <code>queryType</code> used to create <code>queryPool</code> was <code>VK_QUERY_TYPE_TIMESTAMP</code>, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_QUERY_RESULT_PARTIAL_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-queryPool-parameter",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-dstBuffer-parameter",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkQueryResultFlagBits\">VkQueryResultFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyQueryPoolResults-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstBuffer</code>, and <code>queryPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdWriteTimestamp": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-queryPool-01416",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> have been created with a <code>queryType</code> of <code>VK_QUERY_TYPE_TIMESTAMP</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-queryPool-00828",\r
+ "text": " The query identified by <code>queryPool</code> and <code>query</code> <strong class=\"purple\">must</strong> be <em>unavailable</em>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-timestampValidBits-00829",\r
+ "text": " The command pool’s queue family <strong class=\"purple\">must</strong> support a non-zero <code>timestampValidBits</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-pipelineStage-parameter",\r
+ "text": " <code>pipelineStage</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-queryPool-parameter",\r
+ "text": " <code>queryPool</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueryPool</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>queryPool</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-None-00830",\r
+ "text": " All queries used by the command <strong class=\"purple\">must</strong> be unavailable"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteTimestamp-query-00831",\r
+ "text": " If <code>vkCmdWriteTimestamp</code> is called within a render pass instance, the sum of <code>query</code> and the number of bits set in the current subpass’s view mask <strong class=\"purple\">must</strong> be less than or equal to the number of queries in <code>queryPool</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdClearColorImage": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-image-00001",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_TRANSFER_DST_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-image-00002",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-image-00003",\r
+ "text": " If <code>image</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-imageLayout-00004",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresource ranges of <code>image</code> specified in <code>pRanges</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-baseMipLevel-01470",\r
+ "text": " The <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a>::<code>baseMipLevel</code> members of the elements of the <code>pRanges</code> array <strong class=\"purple\">must</strong> each be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-pRanges-01692",\r
+ "text": " For each <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a> element of <code>pRanges</code>, if the <code>levelCount</code> member is not <code>VK_REMAINING_MIP_LEVELS</code>, then <span class=\"eq\"><code>baseMipLevel</code> + <code>levelCount</code></span> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-baseArrayLayer-01472",\r
+ "text": " The <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a>::<code>baseArrayLayer</code> members of the elements of the <code>pRanges</code> array <strong class=\"purple\">must</strong> each be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-pRanges-01693",\r
+ "text": " For each <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a> element of <code>pRanges</code>, if the <code>layerCount</code> member is not <code>VK_REMAINING_ARRAY_LAYERS</code>, then <span class=\"eq\"><code>baseArrayLayer</code> + <code>layerCount</code></span> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-image-00007",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not have a compressed or depth/stencil format"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-imageLayout-parameter",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-pColor-parameter",\r
+ "text": " <code>pColor</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkClearColorValue</code> union"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-pRanges-parameter",\r
+ "text": " <code>pRanges</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>rangeCount</code> valid <code>VkImageSubresourceRange</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-rangeCount-arraylength",\r
+ "text": " <code>rangeCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>image</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-image-01545",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> not use a format listed in &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion&amp;gt;&amp;gt;"\r
+ }\r
+ ],\r
+ "!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-imageLayout-00005",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-imageLayout-01394",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_GENERAL</code>, or <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-commandBuffer-01805",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>image</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearColorImage-commandBuffer-01806",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>image</code> <strong class=\"purple\">must</strong> not be an unprotected image"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdClearDepthStencilImage": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-image-00008",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_TRANSFER_DST_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-image-00009",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-image-00010",\r
+ "text": " If <code>image</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-imageLayout-00011",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresource ranges of <code>image</code> specified in <code>pRanges</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-imageLayout-00012",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> be either of <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-baseMipLevel-01474",\r
+ "text": " The <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a>::<code>baseMipLevel</code> members of the elements of the <code>pRanges</code> array <strong class=\"purple\">must</strong> each be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-pRanges-01694",\r
+ "text": " For each <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a> element of <code>pRanges</code>, if the <code>levelCount</code> member is not <code>VK_REMAINING_MIP_LEVELS</code>, then <span class=\"eq\"><code>baseMipLevel</code> + <code>levelCount</code></span> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-baseArrayLayer-01476",\r
+ "text": " The <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a>::<code>baseArrayLayer</code> members of the elements of the <code>pRanges</code> array <strong class=\"purple\">must</strong> each be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-pRanges-01695",\r
+ "text": " For each <a href=\"#VkImageSubresourceRange\">VkImageSubresourceRange</a> element of <code>pRanges</code>, if the <code>layerCount</code> member is not <code>VK_REMAINING_ARRAY_LAYERS</code>, then <span class=\"eq\"><code>baseArrayLayer</code> + <code>layerCount</code></span> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-image-00014",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have a depth/stencil format"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-imageLayout-parameter",\r
+ "text": " <code>imageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-pDepthStencil-parameter",\r
+ "text": " <code>pDepthStencil</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkClearDepthStencilValue</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-pRanges-parameter",\r
+ "text": " <code>pRanges</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>rangeCount</code> valid <code>VkImageSubresourceRange</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-rangeCount-arraylength",\r
+ "text": " <code>rangeCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>image</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-commandBuffer-01807",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>image</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearDepthStencilImage-commandBuffer-01808",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>image</code> <strong class=\"purple\">must</strong> not be an unprotected image"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdClearAttachments": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-aspectMask-00015",\r
+ "text": " If the <code>aspectMask</code> member of any element of <code>pAttachments</code> contains <code>VK_IMAGE_ASPECT_COLOR_BIT</code>, the <code>colorAttachment</code> member of that element <strong class=\"purple\">must</strong> refer to a valid color attachment in the current subpass"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-pRects-00016",\r
+ "text": " The rectangular region specified by each element of <code>pRects</code> <strong class=\"purple\">must</strong> be contained within the render area of the current render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-pRects-00017",\r
+ "text": " The layers specified by each element of <code>pRects</code> <strong class=\"purple\">must</strong> be contained within every attachment that <code>pAttachments</code> refers to"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-layerCount-01934",\r
+ "text": " The <code>layerCount</code> member of each element of <code>pRects</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-pAttachments-parameter",\r
+ "text": " <code>pAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>attachmentCount</code> valid <code>VkClearAttachment</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-pRects-parameter",\r
+ "text": " <code>pRects</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>rectCount</code> <code>VkClearRect</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-attachmentCount-arraylength",\r
+ "text": " <code>attachmentCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-rectCount-arraylength",\r
+ "text": " <code>rectCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdClearAttachments-baseArrayLayer-00018",\r
+ "text": " If the render pass instance this is recorded in uses multiview, then <code>baseArrayLayer</code> <strong class=\"purple\">must</strong> be zero and <code>layerCount</code> <strong class=\"purple\">must</strong> be one."\r
+ }\r
+ ]\r
+ },\r
+ "VkClearAttachment": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-aspectMask-00019",\r
+ "text": " If <code>aspectMask</code> includes <code>VK_IMAGE_ASPECT_COLOR_BIT</code>, it <strong class=\"purple\">must</strong> not include <code>VK_IMAGE_ASPECT_DEPTH_BIT</code> or <code>VK_IMAGE_ASPECT_STENCIL_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-aspectMask-00020",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not include <code>VK_IMAGE_ASPECT_METADATA_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-clearValue-00021",\r
+ "text": " <code>clearValue</code> <strong class=\"purple\">must</strong> be a valid <code>VkClearValue</code> union"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-aspectMask-parameter",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-aspectMask-requiredbitmask",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-commandBuffer-01809",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then the attachment to be cleared <strong class=\"purple\">must</strong> not be a protected image."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkClearAttachment-commandBuffer-01810",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then the attachment to be cleared <strong class=\"purple\">must</strong> not be an unprotected image."\r
+ }\r
+ ]\r
+ },\r
+ "VkClearDepthStencilValue": {\r
+ "(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-VkClearDepthStencilValue-depth-00022",\r
+ "text": " Unless the <code><a href=\"#VK_EXT_depth_range_unrestricted\">VK_EXT_depth_range_unrestricted</a></code> extension is enabled <code>depth</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ],\r
+ "!(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-VkClearDepthStencilValue-depth-00022",\r
+ "text": " <code>depth</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ]\r
+ },\r
+ "VkClearValue": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkClearValue-depthStencil-00023",\r
+ "text": " <code>depthStencil</code> <strong class=\"purple\">must</strong> be a valid <code>VkClearDepthStencilValue</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdFillBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-dstOffset-00024",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>dstBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-dstOffset-00025",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-size-00026",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-size-00027",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>dstBuffer</code> minus <code>dstOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-size-00028",\r
+ "text": " If <code>size</code> is not equal to <code>VK_WHOLE_SIZE</code>, <code>size</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-dstBuffer-00029",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-dstBuffer-00031",\r
+ "text": " If <code>dstBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-dstBuffer-parameter",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commandBuffer-00030",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics or compute operations"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commandBuffer-01811",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be a protected buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdFillBuffer-commandBuffer-01812",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be an unprotected buffer"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdUpdateBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dstOffset-00032",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>dstBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dataSize-00033",\r
+ "text": " <code>dataSize</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>dstBuffer</code> minus <code>dstOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dstBuffer-00034",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dstBuffer-00035",\r
+ "text": " If <code>dstBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dstOffset-00036",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dataSize-00037",\r
+ "text": " <code>dataSize</code> <strong class=\"purple\">must</strong> be less than or equal to <code>65536</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dataSize-00038",\r
+ "text": " <code>dataSize</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dstBuffer-parameter",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-pData-parameter",\r
+ "text": " <code>pData</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>dataSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-dataSize-arraylength",\r
+ "text": " <code>dataSize</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-commandBuffer-01813",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be a protected buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdUpdateBuffer-commandBuffer-01814",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be an unprotected buffer"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdCopyBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-size-00112",\r
+ "text": " The <code>size</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-srcOffset-00113",\r
+ "text": " The <code>srcOffset</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the size of <code>srcBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-dstOffset-00114",\r
+ "text": " The <code>dstOffset</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the size of <code>dstBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-size-00115",\r
+ "text": " The <code>size</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>srcBuffer</code> minus <code>srcOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-size-00116",\r
+ "text": " The <code>size</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>dstBuffer</code> minus <code>dstOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-pRegions-00117",\r
+ "text": " The union of the source regions, and the union of the destination regions, specified by the elements of <code>pRegions</code>, <strong class=\"purple\">must</strong> not overlap in memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-srcBuffer-00118",\r
+ "text": " <code>srcBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_SRC_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-srcBuffer-00119",\r
+ "text": " If <code>srcBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-dstBuffer-00120",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-dstBuffer-00121",\r
+ "text": " If <code>dstBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-srcBuffer-parameter",\r
+ "text": " <code>srcBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-dstBuffer-parameter",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-pRegions-parameter",\r
+ "text": " <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>regionCount</code> <code>VkBufferCopy</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-regionCount-arraylength",\r
+ "text": " <code>regionCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstBuffer</code>, and <code>srcBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commandBuffer-01822",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>srcBuffer</code> <strong class=\"purple\">must</strong> not be a protected buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commandBuffer-01823",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be a protected buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBuffer-commandBuffer-01824",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be an unprotected buffer"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdCopyImage": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-pRegions-00122",\r
+ "text": " The source region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>srcImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-pRegions-00123",\r
+ "text": " The destination region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>dstImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-pRegions-00124",\r
+ "text": " The union of all source regions, and the union of all destination regions, specified by the elements of <code>pRegions</code>, <strong class=\"purple\">must</strong> not overlap in memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-00126",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_SRC_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImageLayout-00128",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>srcImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImage-00131",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImageLayout-00133",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>dstImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-00136",\r
+ "text": " The sample count of <code>srcImage</code> and <code>dstImage</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcSubresource-01696",\r
+ "text": " The <code>srcSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstSubresource-01697",\r
+ "text": " The <code>dstSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcSubresource-01698",\r
+ "text": " The <span class=\"eq\"><code>srcSubresource.baseArrayLayer</code> + <code>srcSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstSubresource-01699",\r
+ "text": " The <span class=\"eq\"><code>dstSubresource.baseArrayLayer</code> + <code>dstSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcOffset-01783",\r
+ "text": " The <code>srcOffset</code> and and <code>extent</code> members of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> respect the image transfer granularity requirements of <code>commandBuffer</code>’s command pool’s queue family, as described in <a href=\"#VkQueueFamilyProperties\">VkQueueFamilyProperties</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstOffset-01784",\r
+ "text": " The <code>dstOffset</code> and and <code>extent</code> members of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> respect the image transfer granularity requirements of <code>commandBuffer</code>’s command pool’s queue family, as described in <a href=\"#VkQueueFamilyProperties\">VkQueueFamilyProperties</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-parameter",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImageLayout-parameter",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImage-parameter",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImageLayout-parameter",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-pRegions-parameter",\r
+ "text": " <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>regionCount</code> valid <code>VkImageCopy</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-regionCount-arraylength",\r
+ "text": " <code>regionCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstImage</code>, and <code>srcImage</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-00125",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_TRANSFER_SRC_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <a href=\"#vkGetPhysicalDeviceFormatProperties\">vkGetPhysicalDeviceFormatProperties</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImage-00130",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_TRANSFER_DST_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <a href=\"#vkGetPhysicalDeviceFormatProperties\">vkGetPhysicalDeviceFormatProperties</a>"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-00127",\r
+ "text": " If <code>srcImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImage-00132",\r
+ "text": " If <code>dstImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-00135",\r
+ "text": " The <a href=\"#VkFormat\">VkFormat</a> of each of <code>srcImage</code> and <code>dstImage</code> <strong class=\"purple\">must</strong> be compatible, as defined &amp;lt;&amp;lt;copies-images-format-compatibility, below&amp;gt;&amp;gt;"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-01546",\r
+ "text": " If <code>srcImage</code> is non-sparse then the image or <em>disjoint</em> plane to be copied <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImage-01547",\r
+ "text": " If <code>dstImage</code> is non-sparse then the image or <em>disjoint</em> plane that is the destination of the copy <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImage-01548",\r
+ "text": " If the <a href=\"#VkFormat\">VkFormat</a> of each of <code>srcImage</code> and <code>dstImage</code> is not a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,<em>multi-planar format</em>&amp;gt;&amp;gt;, the <a href=\"#VkFormat\">VkFormat</a> of each of <code>srcImage</code> and <code>dstImage</code> <strong class=\"purple\">must</strong> be compatible, as defined &amp;lt;&amp;lt;copies-images-format-compatibility, below&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-None-01549",\r
+ "text": " In a copy to or from a plane of a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar image&amp;gt;&amp;gt;, the <a href=\"#VkFormat\">VkFormat</a> of the image and plane <strong class=\"purple\">must</strong> be compatible according to &amp;lt;&amp;lt;features-formats-compatible-planes,the description of compatible planes&amp;gt;&amp;gt; for the plane being copied"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-aspectMask-01550",\r
+ "text": " When a copy is performed to or from an image with a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt;, the <code>aspectMask</code> of the <code>srcSubresource</code> and/or <code>dstSubresource</code> that refers to the multi-planar image <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code> (with <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code> valid only for a <a href=\"#VkFormat\">VkFormat</a> with three planes)"\r
+ }\r
+ ],\r
+ "!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImageLayout-00129",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImageLayout-00134",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-srcImageLayout-01917",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_GENERAL</code>, or <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-dstImageLayout-01395",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_GENERAL</code>, or <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commandBuffer-01825",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>srcImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commandBuffer-01826",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImage-commandBuffer-01827",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be an unprotected image"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageCopy": {\r
+ "!(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageCopy-aspectMask-00137",\r
+ "text": " The <code>aspectMask</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcOffset-00157",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, all members of <code>srcOffset</code> <strong class=\"purple\">must</strong> be a multiple of the corresponding dimensions of the compressed texel block"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00158",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, <code>extent.width</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width or <span class=\"eq\">(<code>extent.width</code> + <code>srcOffset.x</code>)</span> <strong class=\"purple\">must</strong> equal the source image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00159",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, <code>extent.height</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height or <span class=\"eq\">(<code>extent.height</code> + <code>srcOffset.y</code>)</span> <strong class=\"purple\">must</strong> equal the source image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00160",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, <code>extent.depth</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block depth or <span class=\"eq\">(<code>extent.depth</code> + <code>srcOffset.z</code>)</span> <strong class=\"purple\">must</strong> equal the source image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstOffset-00162",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, all members of <code>dstOffset</code> <strong class=\"purple\">must</strong> be a multiple of the corresponding dimensions of the compressed texel block"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00163",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, <code>extent.width</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width or <span class=\"eq\">(<code>extent.width</code> + <code>dstOffset.x</code>)</span> <strong class=\"purple\">must</strong> equal the destination image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00164",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, <code>extent.height</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height or <span class=\"eq\">(<code>extent.height</code> + <code>dstOffset.y</code>)</span> <strong class=\"purple\">must</strong> equal the destination image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00165",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, <code>extent.depth</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block depth or <span class=\"eq\">(<code>extent.depth</code> + <code>dstOffset.z</code>)</span> <strong class=\"purple\">must</strong> equal the destination image subresource depth"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01551",\r
+ "text": " If neither the calling command’s <code>srcImage</code> nor the calling command’s <code>dstImage</code> has a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion, multi-planar image format&amp;gt;&amp;gt; then the <code>aspectMask</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01552",\r
+ "text": " If the calling command’s <code>srcImage</code> has a <a href=\"#VkFormat\">VkFormat</a> with &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,two planes&amp;gt;&amp;gt; then the <code>srcSubresource</code> <code>aspectMask</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01553",\r
+ "text": " If the calling command’s <code>srcImage</code> has a <a href=\"#VkFormat\">VkFormat</a> with &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,three planes&amp;gt;&amp;gt; then the <code>srcSubresource</code> <code>aspectMask</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01554",\r
+ "text": " If the calling command’s <code>dstImage</code> has a <a href=\"#VkFormat\">VkFormat</a> with &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,two planes&amp;gt;&amp;gt; then the <code>dstSubresource</code> <code>aspectMask</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code> or <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01555",\r
+ "text": " If the calling command’s <code>dstImage</code> has a <a href=\"#VkFormat\">VkFormat</a> with &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,three planes&amp;gt;&amp;gt; then the <code>dstSubresource</code> <code>aspectMask</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01556",\r
+ "text": " If the calling command’s <code>srcImage</code> has a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar image format&amp;gt;&amp;gt; and the <code>dstImage</code> does not have a multi-planar image format, the <code>dstSubresource</code> <code>aspectMask</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_COLOR_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01557",\r
+ "text": " If the calling command’s <code>dstImage</code> has a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar image format&amp;gt;&amp;gt; and the <code>srcImage</code> does not have a multi-planar image format, the <code>srcSubresource</code> <code>aspectMask</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_COLOR_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01727",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, all members of <code>srcOffset</code> <strong class=\"purple\">must</strong> be a multiple of the corresponding dimensions of the compressed texel block"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01728",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>extent.width</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width or <span class=\"eq\">(<code>extent.width</code> + <code>srcOffset.x</code>)</span> <strong class=\"purple\">must</strong> equal the source image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01729",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>extent.height</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height or <span class=\"eq\">(<code>extent.height</code> + <code>srcOffset.y</code>)</span> <strong class=\"purple\">must</strong> equal the source image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01730",\r
+ "text": " If the calling command’s <code>srcImage</code> is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>extent.depth</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block depth or <span class=\"eq\">(<code>extent.depth</code> + <code>srcOffset.z</code>)</span> <strong class=\"purple\">must</strong> equal the source image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01731",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, or a <em>single-plane</em>, “<code>_422</code>” image format, all members of <code>dstOffset</code> <strong class=\"purple\">must</strong> be a multiple of the corresponding dimensions of the compressed texel block"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01732",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>extent.width</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width or <span class=\"eq\">(<code>extent.width</code> + <code>dstOffset.x</code>)</span> <strong class=\"purple\">must</strong> equal the destination image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01733",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>extent.height</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height or <span class=\"eq\">(<code>extent.height</code> + <code>dstOffset.y</code>)</span> <strong class=\"purple\">must</strong> equal the destination image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01734",\r
+ "text": " If the calling command’s <code>dstImage</code> is a compressed format image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>extent.depth</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block depth or <span class=\"eq\">(<code>extent.depth</code> + <code>dstOffset.z</code>)</span> <strong class=\"purple\">must</strong> equal the destination image subresource depth"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkImageCopy-layerCount-00138",\r
+ "text": " The <code>layerCount</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-00139",\r
+ "text": " If either of the calling command’s <code>srcImage</code> or <code>dstImage</code> parameters are of <a href=\"#VkImageType\">VkImageType</a> <code>VK_IMAGE_TYPE_3D</code>, the <code>baseArrayLayer</code> and <code>layerCount</code> members of both <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>1</code>, respectively"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01789",\r
+ "text": " If the calling command’s <code>srcImage</code> or <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_2D</code>, then <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-VkImageCopy-extent-00140",\r
+ "text": " The number of slices of the <code>extent</code> (for 3D) or layers of the <code>srcSubresource</code> (for non-3D) <strong class=\"purple\">must</strong> match the number of slices of the <code>extent</code> (for 3D) or layers of the <code>dstSubresource</code> (for non-3D)"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-00141",\r
+ "text": " If either of the calling command’s <code>srcImage</code> or <code>dstImage</code> parameters are of <a href=\"#VkImageType\">VkImageType</a> <code>VK_IMAGE_TYPE_3D</code>, the <code>baseArrayLayer</code> and <code>layerCount</code> members of the corresponding subresource <strong class=\"purple\">must</strong> be <code>0</code> and <code>1</code>, respectively"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01790",\r
+ "text": " If both <code>srcImage</code> and <code>dstImage</code> are of type <code>VK_IMAGE_TYPE_2D</code> then then <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01791",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_2D</code>, and the <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_3D</code>, then <code>extent.depth</code> <strong class=\"purple\">must</strong> equal to the <code>layerCount</code> member of <code>srcSubresource</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01792",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_2D</code>, and the <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_3D</code>, then <code>extent.depth</code> <strong class=\"purple\">must</strong> equal to the <code>layerCount</code> member of <code>dstSubresource</code>."\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageCopy-aspectMask-00142",\r
+ "text": " The <code>aspectMask</code> member of <code>srcSubresource</code> <strong class=\"purple\">must</strong> specify aspects present in the calling command’s <code>srcImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-aspectMask-00143",\r
+ "text": " The <code>aspectMask</code> member of <code>dstSubresource</code> <strong class=\"purple\">must</strong> specify aspects present in the calling command’s <code>dstImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcOffset-00144",\r
+ "text": " <code>srcOffset.x</code> and <span class=\"eq\">(<code>extent.width</code> + <code>srcOffset.x</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcOffset-00145",\r
+ "text": " <code>srcOffset.y</code> and <span class=\"eq\">(<code>extent.height</code> + <code>srcOffset.y</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-00146",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>srcOffset.y</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcOffset-00147",\r
+ "text": " <code>srcOffset.z</code> and <span class=\"eq\">(<code>extent.depth</code> + <code>srcOffset.z</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01785",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>srcOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01786",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>dstOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcImage-01787",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_2D</code>, then <code>srcOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-01788",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_2D</code>, then <code>dstOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstOffset-00150",\r
+ "text": " <code>dstOffset.x</code> and <span class=\"eq\">(<code>extent.width</code> + <code>dstOffset.x</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstOffset-00151",\r
+ "text": " <code>dstOffset.y</code> and <span class=\"eq\">(<code>extent.height</code> + <code>dstOffset.y</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstImage-00152",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>dstOffset.y</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstOffset-00153",\r
+ "text": " <code>dstOffset.z</code> and <span class=\"eq\">(<code>extent.depth</code> + <code>dstOffset.z</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-srcSubresource-parameter",\r
+ "text": " <code>srcSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageCopy-dstSubresource-parameter",\r
+ "text": " <code>dstSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageSubresourceLayers": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceLayers-aspectMask-00167",\r
+ "text": " If <code>aspectMask</code> contains <code>VK_IMAGE_ASPECT_COLOR_BIT</code>, it <strong class=\"purple\">must</strong> not contain either of <code>VK_IMAGE_ASPECT_DEPTH_BIT</code> or <code>VK_IMAGE_ASPECT_STENCIL_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceLayers-aspectMask-00168",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not contain <code>VK_IMAGE_ASPECT_METADATA_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceLayers-layerCount-01700",\r
+ "text": " <code>layerCount</code> <strong class=\"purple\">must</strong> be greater than 0"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceLayers-aspectMask-parameter",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageAspectFlagBits\">VkImageAspectFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSubresourceLayers-aspectMask-requiredbitmask",\r
+ "text": " <code>aspectMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdCopyBufferToImage": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-pRegions-00171",\r
+ "text": " <code>srcBuffer</code> <strong class=\"purple\">must</strong> be large enough to contain all buffer locations that are accessed according to &amp;lt;&amp;lt;copies-buffers-images-addressing,Buffer and Image Addressing&amp;gt;&amp;gt;, for each element of <code>pRegions</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-pRegions-00172",\r
+ "text": " The image region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>dstImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-pRegions-00173",\r
+ "text": " The union of all source regions, and the union of all destination regions, specified by the elements of <code>pRegions</code>, <strong class=\"purple\">must</strong> not overlap in memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-srcBuffer-00174",\r
+ "text": " <code>srcBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_SRC_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-srcBuffer-00176",\r
+ "text": " If <code>srcBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImage-00177",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImage-00178",\r
+ "text": " If <code>dstImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImage-00179",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> have a sample count equal to <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImageLayout-00180",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>dstImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-imageSubresource-01701",\r
+ "text": " The <code>imageSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-imageSubresource-01702",\r
+ "text": " The <span class=\"eq\"><code>imageSubresource.baseArrayLayer</code> + <code>imageSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-imageOffset-01793",\r
+ "text": " The <code>imageOffset</code> and and <code>imageExtent</code> members of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> respect the image transfer granularity requirements of <code>commandBuffer</code>’s command pool’s queue family, as described in <a href=\"#VkQueueFamilyProperties\">VkQueueFamilyProperties</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-srcBuffer-parameter",\r
+ "text": " <code>srcBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImage-parameter",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImageLayout-parameter",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-pRegions-parameter",\r
+ "text": " <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>regionCount</code> valid <code>VkBufferImageCopy</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-regionCount-arraylength",\r
+ "text": " <code>regionCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstImage</code>, and <code>srcBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImage-00175",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_TRANSFER_DST_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <a href=\"#vkGetPhysicalDeviceFormatProperties\">vkGetPhysicalDeviceFormatProperties</a>"\r
+ }\r
+ ],\r
+ "!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImageLayout-00181",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-dstImageLayout-01396",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code>, <code>VK_IMAGE_LAYOUT_GENERAL</code>, or <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commandBuffer-01828",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>srcBuffer</code> <strong class=\"purple\">must</strong> not be a protected buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commandBuffer-01829",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyBufferToImage-commandBuffer-01830",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be an unprotected image"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdCopyImageToBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-pRegions-00182",\r
+ "text": " The image region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>srcImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-pRegions-00183",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be large enough to contain all buffer locations that are accessed according to &amp;lt;&amp;lt;copies-buffers-images-addressing,Buffer and Image Addressing&amp;gt;&amp;gt;, for each element of <code>pRegions</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-pRegions-00184",\r
+ "text": " The union of all source regions, and the union of all destination regions, specified by the elements of <code>pRegions</code>, <strong class=\"purple\">must</strong> not overlap in memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImage-00186",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_SRC_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImage-00187",\r
+ "text": " If <code>srcImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImage-00188",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> have a sample count equal to <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImageLayout-00189",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>srcImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-dstBuffer-00191",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-dstBuffer-00192",\r
+ "text": " If <code>dstBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-imageSubresource-01703",\r
+ "text": " The <code>imageSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-imageSubresource-01704",\r
+ "text": " The <span class=\"eq\"><code>imageSubresource.baseArrayLayer</code> + <code>imageSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-imageOffset-01794",\r
+ "text": " The <code>imageOffset</code> and and <code>imageExtent</code> members of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> respect the image transfer granularity requirements of <code>commandBuffer</code>’s command pool’s queue family, as described in <a href=\"#VkQueueFamilyProperties\">VkQueueFamilyProperties</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImage-parameter",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImageLayout-parameter",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-dstBuffer-parameter",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-pRegions-parameter",\r
+ "text": " <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>regionCount</code> valid <code>VkBufferImageCopy</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-regionCount-arraylength",\r
+ "text": " <code>regionCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstBuffer</code>, and <code>srcImage</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImage-00185",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_TRANSFER_SRC_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <a href=\"#vkGetPhysicalDeviceFormatProperties\">vkGetPhysicalDeviceFormatProperties</a>"\r
+ }\r
+ ],\r
+ "!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImageLayout-00190",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-srcImageLayout-01397",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>, <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commandBuffer-01831",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>srcImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commandBuffer-01832",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be a protected buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdCopyImageToBuffer-commandBuffer-01833",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstBuffer</code> <strong class=\"purple\">must</strong> not be an unprotected buffer"\r
+ }\r
+ ]\r
+ },\r
+ "VkBufferImageCopy": {\r
+ "!(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferOffset-00193",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter’s format is not a depth/stencil format, then <code>bufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of the format’s element size"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferRowLength-00203",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, <code>bufferRowLength</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferImageHeight-00204",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, <code>bufferImageHeight</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageOffset-00205",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, all members of <code>imageOffset</code> <strong class=\"purple\">must</strong> be a multiple of the corresponding dimensions of the compressed texel block"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferOffset-00206",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, <code>bufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block size in bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageExtent-00207",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, <code>imageExtent.width</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width or <span class=\"eq\">(<code>imageExtent.width</code> + <code>imageOffset.x</code>)</span> <strong class=\"purple\">must</strong> equal the image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageExtent-00208",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, <code>imageExtent.height</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height or <span class=\"eq\">(<code>imageExtent.height</code> + <code>imageOffset.y</code>)</span> <strong class=\"purple\">must</strong> equal the image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageExtent-00209",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, <code>imageExtent.depth</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block depth or <span class=\"eq\">(<code>imageExtent.depth</code> + <code>imageOffset.z</code>)</span> <strong class=\"purple\">must</strong> equal the image subresource depth"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferOffset-01558",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter’s format is not a depth/stencil format or a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt;, then <code>bufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of the format’s element size"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferOffset-01559",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter’s format is a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt;, then <code>bufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of the element size of the compatible format for the format and the <code>aspectMask</code> of the <code>imageSubresource</code> as defined in &amp;lt;&amp;lt;features-formats-compatible-planes&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01735",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>bufferRowLength</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01736",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>bufferImageHeight</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01737",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, all members of <code>imageOffset</code> <strong class=\"purple\">must</strong> be a multiple of the corresponding dimensions of the compressed texel block"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01738",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>bufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block size in bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01739",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>imageExtent.width</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block width or <span class=\"eq\">(<code>imageExtent.width</code> + <code>imageOffset.x</code>)</span> <strong class=\"purple\">must</strong> equal the image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01740",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>imageExtent.height</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block height or <span class=\"eq\">(<code>imageExtent.height</code> + <code>imageOffset.y</code>)</span> <strong class=\"purple\">must</strong> equal the image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-01741",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is a compressed image, or a <em>single-plane</em>, “<code>_422</code>” image format, <code>imageExtent.depth</code> <strong class=\"purple\">must</strong> be a multiple of the compressed texel block depth or <span class=\"eq\">(<code>imageExtent.depth</code> + <code>imageOffset.z</code>)</span> <strong class=\"purple\">must</strong> equal the image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-aspectMask-01560",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter’s format is a &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion,multi-planar format&amp;gt;&amp;gt;, then the <code>aspectMask</code> member of <code>imageSubresource</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_ASPECT_PLANE_0_BIT</code>, <code>VK_IMAGE_ASPECT_PLANE_1_BIT</code>, or <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code> (with <code>VK_IMAGE_ASPECT_PLANE_2_BIT</code> valid only for image formats with three planes)"\r
+ }\r
+ ],\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferOffset-00194",\r
+ "text": " <code>bufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferRowLength-00195",\r
+ "text": " <code>bufferRowLength</code> <strong class=\"purple\">must</strong> be <code>0</code>, or greater than or equal to the <code>width</code> member of <code>imageExtent</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-bufferImageHeight-00196",\r
+ "text": " <code>bufferImageHeight</code> <strong class=\"purple\">must</strong> be <code>0</code>, or greater than or equal to the <code>height</code> member of <code>imageExtent</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageOffset-00197",\r
+ "text": " <code>imageOffset.x</code> and <span class=\"eq\">(<code>imageExtent.width</code> + <code>imageOffset.x</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageOffset-00198",\r
+ "text": " <code>imageOffset.y</code> and <span class=\"eq\">(imageExtent.height + <code>imageOffset.y</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-srcImage-00199",\r
+ "text": " If the calling command’s <code>srcImage</code> (<a href=\"#vkCmdCopyImageToBuffer\">vkCmdCopyImageToBuffer</a>) or <code>dstImage</code> (<a href=\"#vkCmdCopyBufferToImage\">vkCmdCopyBufferToImage</a>) is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>imageOffset.y</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>imageExtent.height</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageOffset-00200",\r
+ "text": " <code>imageOffset.z</code> and <span class=\"eq\">(imageExtent.depth + <code>imageOffset.z</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-srcImage-00201",\r
+ "text": " If the calling command’s <code>srcImage</code> (<a href=\"#vkCmdCopyImageToBuffer\">vkCmdCopyImageToBuffer</a>) or <code>dstImage</code> (<a href=\"#vkCmdCopyBufferToImage\">vkCmdCopyBufferToImage</a>) is of type <code>VK_IMAGE_TYPE_1D</code> or <code>VK_IMAGE_TYPE_2D</code>, then <code>imageOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>imageExtent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-aspectMask-00211",\r
+ "text": " The <code>aspectMask</code> member of <code>imageSubresource</code> <strong class=\"purple\">must</strong> specify aspects present in the calling command’s <code>VkImage</code> parameter"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-aspectMask-00212",\r
+ "text": " The <code>aspectMask</code> member of <code>imageSubresource</code> <strong class=\"purple\">must</strong> only have a single bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-baseArrayLayer-00213",\r
+ "text": " If the calling command’s <code>VkImage</code> parameter is of <a href=\"#VkImageType\">VkImageType</a> <code>VK_IMAGE_TYPE_3D</code>, the <code>baseArrayLayer</code> and <code>layerCount</code> members of <code>imageSubresource</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>1</code>, respectively"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-None-00214",\r
+ "text": " When copying to the depth aspect of an image subresource, the data in the source buffer <strong class=\"purple\">must</strong> be in the range <span class=\"eq\">[0,1]</span>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBufferImageCopy-imageSubresource-parameter",\r
+ "text": " <code>imageSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBlitImage": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-pRegions-00215",\r
+ "text": " The source region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>srcImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-pRegions-00216",\r
+ "text": " The destination region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>dstImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-pRegions-00217",\r
+ "text": " The union of all destination regions, specified by the elements of <code>pRegions</code>, <strong class=\"purple\">must</strong> not overlap in memory with any texel that <strong class=\"purple\">may</strong> be sampled during the blit operation"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00218",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_BLIT_SRC_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00219",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_SRC_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00220",\r
+ "text": " If <code>srcImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImageLayout-00221",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>srcImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImage-00223",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> use a format that supports <code>VK_FORMAT_FEATURE_BLIT_DST_BIT</code>, which is indicated by <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for linearly tiled images) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> (for optimally tiled images) - as returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImage-00224",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with <code>VK_IMAGE_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImage-00225",\r
+ "text": " If <code>dstImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImageLayout-00226",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>dstImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00228",\r
+ "text": " The sample count of <code>srcImage</code> and <code>dstImage</code> <strong class=\"purple\">must</strong> both be equal to <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00229",\r
+ "text": " If either of <code>srcImage</code> or <code>dstImage</code> was created with a signed integer <a href=\"#VkFormat\">VkFormat</a>, the other <strong class=\"purple\">must</strong> also have been created with a signed integer <a href=\"#VkFormat\">VkFormat</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00230",\r
+ "text": " If either of <code>srcImage</code> or <code>dstImage</code> was created with an unsigned integer <a href=\"#VkFormat\">VkFormat</a>, the other <strong class=\"purple\">must</strong> also have been created with an unsigned integer <a href=\"#VkFormat\">VkFormat</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00231",\r
+ "text": " If either of <code>srcImage</code> or <code>dstImage</code> was created with a depth/stencil format, the other <strong class=\"purple\">must</strong> have exactly the same format"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00232",\r
+ "text": " If <code>srcImage</code> was created with a depth/stencil format, <code>filter</code> <strong class=\"purple\">must</strong> be <code>VK_FILTER_NEAREST</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-00233",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> have been created with a <code>samples</code> value of <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImage-00234",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with a <code>samples</code> value of <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-filter-00235",\r
+ "text": " If <code>filter</code> is <code>VK_FILTER_LINEAR</code>, <code>srcImage</code> <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcSubresource-01705",\r
+ "text": " The <code>srcSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstSubresource-01706",\r
+ "text": " The <code>dstSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcSubresource-01707",\r
+ "text": " The <span class=\"eq\"><code>srcSubresource.baseArrayLayer</code> + <code>srcSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstSubresource-01708",\r
+ "text": " The <span class=\"eq\"><code>dstSubresource.baseArrayLayer</code> + <code>dstSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-parameter",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImageLayout-parameter",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImage-parameter",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImageLayout-parameter",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-pRegions-parameter",\r
+ "text": " <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>regionCount</code> valid <code>VkImageBlit</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-filter-parameter",\r
+ "text": " <code>filter</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFilter\">VkFilter</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-regionCount-arraylength",\r
+ "text": " <code>regionCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstImage</code>, and <code>srcImage</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImage-01561",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> not use a format listed in &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImage-01562",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> not use a format listed in &amp;lt;&amp;lt;features-formats-requiring-sampler-ycbcr-conversion&amp;gt;&amp;gt;"\r
+ }\r
+ ],\r
+ "!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImageLayout-00222",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImageLayout-00227",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-srcImageLayout-01398",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>, <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-dstImageLayout-01399",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>, <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-filter-00236",\r
+ "text": " If <code>filter</code> is <code>VK_FILTER_CUBIC_IMG</code>, <code>srcImage</code> <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-filter-00237",\r
+ "text": " If <code>filter</code> is <code>VK_FILTER_CUBIC_IMG</code>, <code>srcImage</code> <strong class=\"purple\">must</strong> have a <a href=\"#VkImageType\">VkImageType</a> of <code>VK_IMAGE_TYPE_3D</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commandBuffer-01834",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>srcImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commandBuffer-01835",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBlitImage-commandBuffer-01836",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be an unprotected image"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageBlit": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageBlit-aspectMask-00238",\r
+ "text": " The <code>aspectMask</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-layerCount-00239",\r
+ "text": " The <code>layerCount</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcImage-00240",\r
+ "text": " If either of the calling command’s <code>srcImage</code> or <code>dstImage</code> parameters are of <a href=\"#VkImageType\">VkImageType</a> <code>VK_IMAGE_TYPE_3D</code>, the <code>baseArrayLayer</code> and <code>layerCount</code> members of both <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>1</code>, respectively"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-aspectMask-00241",\r
+ "text": " The <code>aspectMask</code> member of <code>srcSubresource</code> <strong class=\"purple\">must</strong> specify aspects present in the calling command’s <code>srcImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-aspectMask-00242",\r
+ "text": " The <code>aspectMask</code> member of <code>dstSubresource</code> <strong class=\"purple\">must</strong> specify aspects present in the calling command’s <code>dstImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcOffset-00243",\r
+ "text": " <code>srcOffset</code>[0].<code>x</code> and <code>srcOffset</code>[1].<code>x</code> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcOffset-00244",\r
+ "text": " <code>srcOffset</code>[0].<code>y</code> and <code>srcOffset</code>[1].<code>y</code> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcImage-00245",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>srcOffset</code>[0].y <strong class=\"purple\">must</strong> be <code>0</code> and <code>srcOffset</code>[1].y <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcOffset-00246",\r
+ "text": " <code>srcOffset</code>[0].<code>z</code> and <code>srcOffset</code>[1].<code>z</code> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcImage-00247",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_1D</code> or <code>VK_IMAGE_TYPE_2D</code>, then <code>srcOffset</code>[0].z <strong class=\"purple\">must</strong> be <code>0</code> and <code>srcOffset</code>[1].z <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-dstOffset-00248",\r
+ "text": " <code>dstOffset</code>[0].<code>x</code> and <code>dstOffset</code>[1].<code>x</code> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-dstOffset-00249",\r
+ "text": " <code>dstOffset</code>[0].<code>y</code> and <code>dstOffset</code>[1].<code>y</code> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-dstImage-00250",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>dstOffset</code>[0].y <strong class=\"purple\">must</strong> be <code>0</code> and <code>dstOffset</code>[1].y <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-dstOffset-00251",\r
+ "text": " <code>dstOffset</code>[0].<code>z</code> and <code>dstOffset</code>[1].<code>z</code> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-dstImage-00252",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_1D</code> or <code>VK_IMAGE_TYPE_2D</code>, then <code>dstOffset</code>[0].z <strong class=\"purple\">must</strong> be <code>0</code> and <code>dstOffset</code>[1].z <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-srcSubresource-parameter",\r
+ "text": " <code>srcSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageBlit-dstSubresource-parameter",\r
+ "text": " <code>dstSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdResolveImage": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-pRegions-00253",\r
+ "text": " The source region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>srcImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-pRegions-00254",\r
+ "text": " The destination region specified by each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be a region that is contained within <code>dstImage</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-pRegions-00255",\r
+ "text": " The union of all source regions, and the union of all destination regions, specified by the elements of <code>pRegions</code>, <strong class=\"purple\">must</strong> not overlap in memory"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImage-00256",\r
+ "text": " If <code>srcImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImage-00257",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> have a sample count equal to any valid sample count value other than <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImage-00258",\r
+ "text": " If <code>dstImage</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImage-00259",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> have a sample count equal to <code>VK_SAMPLE_COUNT_1_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImageLayout-00260",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>srcImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImageLayout-00262",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> specify the layout of the image subresources of <code>dstImage</code> specified in <code>pRegions</code> at the time this command is executed on a <code>VkDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImage-00264",\r
+ "text": " If <code>dstImage</code> was created with <code>tiling</code> equal to <code>VK_IMAGE_TILING_LINEAR</code>, <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with a <code>format</code> that supports being a color attachment, as specified by the <code>VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImage-00265",\r
+ "text": " If <code>dstImage</code> was created with <code>tiling</code> equal to <code>VK_IMAGE_TILING_OPTIMAL</code>, <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with a <code>format</code> that supports being a color attachment, as specified by the <code>VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT</code> flag in <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImage-01386",\r
+ "text": " <code>srcImage</code> and <code>dstImage</code> <strong class=\"purple\">must</strong> have been created with the same image format"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcSubresource-01709",\r
+ "text": " The <code>srcSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstSubresource-01710",\r
+ "text": " The <code>dstSubresource.mipLevel</code> member of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcSubresource-01711",\r
+ "text": " The <span class=\"eq\"><code>srcSubresource.baseArrayLayer</code> + <code>srcSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>srcImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstSubresource-01712",\r
+ "text": " The <span class=\"eq\"><code>dstSubresource.baseArrayLayer</code> + <code>dstSubresource.layerCount</code></span> of each element of <code>pRegions</code> <strong class=\"purple\">must</strong> be less than or equal to the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>dstImage</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImage-parameter",\r
+ "text": " <code>srcImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImageLayout-parameter",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImage-parameter",\r
+ "text": " <code>dstImage</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImageLayout-parameter",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageLayout\">VkImageLayout</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-pRegions-parameter",\r
+ "text": " <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>regionCount</code> valid <code>VkImageResolve</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-regionCount-arraylength",\r
+ "text": " <code>regionCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commonparent",\r
+ "text": " Each of <code>commandBuffer</code>, <code>dstImage</code>, and <code>srcImage</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImageLayout-00261",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImageLayout-00263",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-srcImageLayout-01400",\r
+ "text": " <code>srcImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>, <code>VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-dstImageLayout-01401",\r
+ "text": " <code>dstImageLayout</code> <strong class=\"purple\">must</strong> be <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code>, <code>VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL</code> or <code>VK_IMAGE_LAYOUT_GENERAL</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commandBuffer-01837",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>srcImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commandBuffer-01838",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be a protected image"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdResolveImage-commandBuffer-01839",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, then <code>dstImage</code> <strong class=\"purple\">must</strong> not be an unprotected image"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageResolve": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkImageResolve-aspectMask-00266",\r
+ "text": " The <code>aspectMask</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> only contain <code>VK_IMAGE_ASPECT_COLOR_BIT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-layerCount-00267",\r
+ "text": " The <code>layerCount</code> member of <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> match"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcImage-00268",\r
+ "text": " If either of the calling command’s <code>srcImage</code> or <code>dstImage</code> parameters are of <a href=\"#VkImageType\">VkImageType</a> <code>VK_IMAGE_TYPE_3D</code>, the <code>baseArrayLayer</code> and <code>layerCount</code> members of both <code>srcSubresource</code> and <code>dstSubresource</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>1</code>, respectively"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcOffset-00269",\r
+ "text": " <code>srcOffset.x</code> and <span class=\"eq\">(<code>extent.width</code> + <code>srcOffset.x</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcOffset-00270",\r
+ "text": " <code>srcOffset.y</code> and <span class=\"eq\">(<code>extent.height</code> + <code>srcOffset.y</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcImage-00271",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>srcOffset.y</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcOffset-00272",\r
+ "text": " <code>srcOffset.z</code> and <span class=\"eq\">(<code>extent.depth</code> + <code>srcOffset.z</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the source image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcImage-00273",\r
+ "text": " If the calling command’s <code>srcImage</code> is of type <code>VK_IMAGE_TYPE_1D</code> or <code>VK_IMAGE_TYPE_2D</code>, then <code>srcOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-dstOffset-00274",\r
+ "text": " <code>dstOffset.x</code> and <span class=\"eq\">(<code>extent.width</code> + <code>dstOffset.x</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource width"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-dstOffset-00275",\r
+ "text": " <code>dstOffset.y</code> and <span class=\"eq\">(<code>extent.height</code> + <code>dstOffset.y</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource height"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-dstImage-00276",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_1D</code>, then <code>dstOffset.y</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.height</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-dstOffset-00277",\r
+ "text": " <code>dstOffset.z</code> and <span class=\"eq\">(<code>extent.depth</code> + <code>dstOffset.z</code>)</span> <strong class=\"purple\">must</strong> both be greater than or equal to <code>0</code> and less than or equal to the destination image subresource depth"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-dstImage-00278",\r
+ "text": " If the calling command’s <code>dstImage</code> is of type <code>VK_IMAGE_TYPE_1D</code> or <code>VK_IMAGE_TYPE_2D</code>, then <code>dstOffset.z</code> <strong class=\"purple\">must</strong> be <code>0</code> and <code>extent.depth</code> <strong class=\"purple\">must</strong> be <code>1</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-srcSubresource-parameter",\r
+ "text": " <code>srcSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageResolve-dstSubresource-parameter",\r
+ "text": " <code>dstSubresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresourceLayers</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdWriteBufferMarkerAMD": {\r
+ "(VK_AMD_buffer_marker)": [\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-dstOffset-01798",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>dstBuffer</code> minus <code>4</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-dstBuffer-01799",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created with <code>VK_BUFFER_USAGE_TRANSFER_DST_BIT</code> usage flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-dstBuffer-01800",\r
+ "text": " If <code>dstBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-dstOffset-01801",\r
+ "text": " <code>dstOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-pipelineStage-parameter",\r
+ "text": " <code>pipelineStage</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineStageFlagBits\">VkPipelineStageFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-dstBuffer-parameter",\r
+ "text": " <code>dstBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support transfer, graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdWriteBufferMarkerAMD-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and <code>dstBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineInputAssemblyStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-topology-00428",\r
+ "text": " If <code>topology</code> is <code>VK_PRIMITIVE_TOPOLOGY_POINT_LIST</code>, <code>VK_PRIMITIVE_TOPOLOGY_LINE_LIST</code>, <code>VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST</code>, <code>VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY</code>, <code>VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY</code> or <code>VK_PRIMITIVE_TOPOLOGY_PATCH_LIST</code>, <code>primitiveRestartEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-topology-00429",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-geometryShader,geometry shaders&amp;gt;&amp;gt; feature is not enabled, <code>topology</code> <strong class=\"purple\">must</strong> not be any of <code>VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY</code>, <code>VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY</code>, <code>VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY</code> or <code>VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-topology-00430",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-tessellationShader,tessellation shaders&amp;gt;&amp;gt; feature is not enabled, <code>topology</code> <strong class=\"purple\">must</strong> not be <code>VK_PRIMITIVE_TOPOLOGY_PATCH_LIST</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineInputAssemblyStateCreateInfo-topology-parameter",\r
+ "text": " <code>topology</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPrimitiveTopology\">VkPrimitiveTopology</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBindIndexBuffer": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-offset-00431",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-offset-00432",\r
+ "text": " The sum of <code>offset</code> and the address of the range of <code>VkDeviceMemory</code> object that is backing <code>buffer</code>, <strong class=\"purple\">must</strong> be a multiple of the type indicated by <code>indexType</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-buffer-00433",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDEX_BUFFER_BIT</code> flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-buffer-00434",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-indexType-parameter",\r
+ "text": " <code>indexType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkIndexType\">VkIndexType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindIndexBuffer-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDraw": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-renderPass-00435",\r
+ "text": " The current render pass <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-subpass-00436",\r
+ "text": " The subpass index of the current render pass <strong class=\"purple\">must</strong> be equal to the <code>subpass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00437",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00438",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00439",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00440",\r
+ "text": " All vertex input bindings accessed via vertex input variables declared in the vertex shader entry point’s interface <strong class=\"purple\">must</strong> have valid buffers bound"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00441",\r
+ "text": " For a given vertex buffer binding, any attribute data fetched <strong class=\"purple\">must</strong> be entirely contained within the corresponding vertex buffer binding, as described in &amp;lt;&amp;lt;fxvertex-input&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00442",\r
+ "text": " A valid graphics pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00443",\r
+ "text": " If the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> requires any dynamic state, that state <strong class=\"purple\">must</strong> have been set on the current command buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00444",\r
+ "text": " Every input attachment used by the current subpass <strong class=\"purple\">must</strong> be bound to the pipeline via a descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00445",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00446",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00447",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00448",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00449",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-linearTilingFeatures-00450",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-01499",\r
+ "text": " Image subresources used as attachments in the current render pass <strong class=\"purple\">must</strong> not be accessed in any way other than as an attachment by this command."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-linearTilingFeatures-00451",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-None-00452",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> not have a <a href=\"#VkImageViewType\">VkImageViewType</a> of <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-maxMultiviewInstanceIndex-00453",\r
+ "text": " If the draw is recorded in a render pass instance with multiview enabled, the maximum instance index <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>::<code>maxMultiviewInstanceIndex</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-commandBuffer-01850",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-commandBuffer-01851",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-commandBuffer-01852",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the framebuffer-space pipeline stages in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDraw-sampleLocationsEnable-01512",\r
+ "text": " If the bound graphics pipeline was created with <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>::<code>sampleLocationsEnable</code> set to <code>VK_TRUE</code> and the current subpass has a depth/stencil attachment, then that attachment <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> bit set"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDrawIndexed": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-renderPass-00454",\r
+ "text": " The current render pass <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-subpass-00455",\r
+ "text": " The subpass index of the current render pass <strong class=\"purple\">must</strong> be equal to the <code>subpass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00456",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00457",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00458",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00459",\r
+ "text": " All vertex input bindings accessed via vertex input variables declared in the vertex shader entry point’s interface <strong class=\"purple\">must</strong> have valid buffers bound"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00460",\r
+ "text": " For a given vertex buffer binding, any attribute data fetched <strong class=\"purple\">must</strong> be entirely contained within the corresponding vertex buffer binding, as described in &amp;lt;&amp;lt;fxvertex-input&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00461",\r
+ "text": " A valid graphics pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00462",\r
+ "text": " If the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> requires any dynamic state, that state <strong class=\"purple\">must</strong> have been set on the current command buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-indexSize-00463",\r
+ "text": " <span class=\"eq\">(<code>indexSize</code> * (<code>firstIndex</code> + <code>indexCount</code>) + <code>offset</code>)</span> <strong class=\"purple\">must</strong> be less than or equal to the size of the bound index buffer, with indexSize being based on the type specified by <code>indexType</code>, where the index buffer, <code>indexType</code>, and <code>offset</code> are specified via <code>vkCmdBindIndexBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00464",\r
+ "text": " Every input attachment used by the current subpass <strong class=\"purple\">must</strong> be bound to the pipeline via a descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00465",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00466",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00467",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00468",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00469",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-linearTilingFeatures-00470",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-01500",\r
+ "text": " Image subresources used as attachments in the current render pass <strong class=\"purple\">must</strong> not be accessed in any way other than as an attachment by this command."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-linearTilingFeatures-00471",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-None-00472",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> not have a <a href=\"#VkImageViewType\">VkImageViewType</a> of <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-maxMultiviewInstanceIndex-00473",\r
+ "text": " If the draw is recorded in a render pass instance with multiview enabled, the maximum instance index <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>::<code>maxMultiviewInstanceIndex</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-commandBuffer-01853",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-commandBuffer-01854",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-commandBuffer-01855",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the framebuffer-space pipeline stages in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexed-sampleLocationsEnable-01513",\r
+ "text": " If the bound graphics pipeline was created with <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>::<code>sampleLocationsEnable</code> set to <code>VK_TRUE</code> and the current subpass has a depth/stencil attachment, then that attachment <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> bit set"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDrawIndirect": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-buffer-00474",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-buffer-01660",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-offset-00475",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-drawCount-00476",\r
+ "text": " If <code>drawCount</code> is greater than <code>1</code>, <code>stride</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code> and <strong class=\"purple\">must</strong> be greater than or equal to <code>sizeof</code>(<code>VkDrawIndirectCommand</code>)"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-drawCount-00477",\r
+ "text": " If the <a href=\"#features-features-multiDrawIndirect\">multi-draw indirect</a> feature is not enabled, <code>drawCount</code> <strong class=\"purple\">must</strong> be <code>0</code> or <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-firstInstance-00478",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-drawIndirectFirstInstance,drawIndirectFirstInstance&amp;gt;&amp;gt; feature is not enabled, all the <code>firstInstance</code> members of the <code>VkDrawIndirectCommand</code> structures accessed by this command <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-renderPass-00479",\r
+ "text": " The current render pass <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-subpass-00480",\r
+ "text": " The subpass index of the current render pass <strong class=\"purple\">must</strong> be equal to the <code>subpass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00481",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00482",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00483",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00484",\r
+ "text": " All vertex input bindings accessed via vertex input variables declared in the vertex shader entry point’s interface <strong class=\"purple\">must</strong> have valid buffers bound"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00485",\r
+ "text": " A valid graphics pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00486",\r
+ "text": " If the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> requires any dynamic state, that state <strong class=\"purple\">must</strong> have been set on the current command buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-drawCount-00487",\r
+ "text": " If <code>drawCount</code> is equal to <code>1</code>, <span class=\"eq\">(<code>offset</code> + <code>sizeof</code>(<a href=\"#VkDrawIndirectCommand\">VkDrawIndirectCommand</a>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-drawCount-00488",\r
+ "text": " If <code>drawCount</code> is greater than <code>1</code>, <span class=\"eq\">(<code>stride</code> {times} (<code>drawCount</code> - 1) + <code>offset</code> + <code>sizeof</code>(<a href=\"#VkDrawIndirectCommand\">VkDrawIndirectCommand</a>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-drawCount-00489",\r
+ "text": " <code>drawCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDrawIndirectCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00490",\r
+ "text": " Every input attachment used by the current subpass <strong class=\"purple\">must</strong> be bound to the pipeline via a descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00491",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00492",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00493",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00494",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00495",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-linearTilingFeatures-00496",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-01501",\r
+ "text": " Image subresources used as attachments in the current render pass <strong class=\"purple\">must</strong> not be accessed in any way other than as an attachment by this command."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-linearTilingFeatures-00497",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-None-00498",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> not have a <a href=\"#VkImageViewType\">VkImageViewType</a> of <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-maxMultiviewInstanceIndex-00499",\r
+ "text": " If the draw is recorded in a render pass instance with multiview enabled, the maximum instance index <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>::<code>maxMultiviewInstanceIndex</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commandBuffer-01856",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commandBuffer-01857",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-commandBuffer-01858",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the framebuffer-space pipeline stages in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirect-sampleLocationsEnable-01514",\r
+ "text": " If the bound graphics pipeline was created with <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>::<code>sampleLocationsEnable</code> set to <code>VK_TRUE</code> and the current subpass has a depth/stencil attachment, then that attachment <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> bit set"\r
+ }\r
+ ]\r
+ },\r
+ "VkDrawIndirectCommand": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDrawIndirectCommand-None-00500",\r
+ "text": " For a given vertex buffer binding, any attribute data fetched <strong class=\"purple\">must</strong> be entirely contained within the corresponding vertex buffer binding, as described in &amp;lt;&amp;lt;fxvertex-input&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDrawIndirectCommand-firstInstance-00501",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-drawIndirectFirstInstance,drawIndirectFirstInstance&amp;gt;&amp;gt; feature is not enabled, <code>firstInstance</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDrawIndirectCountAMD": {\r
+ "(VK_AMD_draw_indirect_count)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-buffer-01661",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-buffer-01662",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBuffer-01663",\r
+ "text": " If <code>countBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBuffer-01664",\r
+ "text": " <code>countBuffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-offset-00502",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBufferOffset-00503",\r
+ "text": " <code>countBufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-stride-00504",\r
+ "text": " <code>stride</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code> and <strong class=\"purple\">must</strong> be greater than or equal to <code>sizeof</code>(<code>VkDrawIndirectCommand</code>)"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-maxDrawCount-00505",\r
+ "text": " If <code>maxDrawCount</code> is greater than or equal to <code>1</code>, <span class=\"eq\">(<code>stride</code> {times} (<code>maxDrawCount</code> - 1) + <code>offset</code> + <code>sizeof</code>(<code>VkDrawIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-firstInstance-00506",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-drawIndirectFirstInstance,drawIndirectFirstInstance&amp;gt;&amp;gt; feature is not enabled, all the <code>firstInstance</code> members of the <code>VkDrawIndirectCommand</code> structures accessed by this command <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-renderPass-00507",\r
+ "text": " The current render pass <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-subpass-00508",\r
+ "text": " The subpass index of the current render pass <strong class=\"purple\">must</strong> be equal to the <code>subpass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00509",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00510",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00511",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00512",\r
+ "text": " All vertex input bindings accessed via vertex input variables declared in the vertex shader entry point’s interface <strong class=\"purple\">must</strong> have valid buffers bound"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00513",\r
+ "text": " A valid graphics pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00514",\r
+ "text": " If the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> requires any dynamic state, that state <strong class=\"purple\">must</strong> have been set on the current command buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBuffer-00515",\r
+ "text": " If the count stored in <code>countBuffer</code> is equal to <code>1</code>, <span class=\"eq\">(<code>offset</code> + <code>sizeof</code>(<code>VkDrawIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBuffer-00516",\r
+ "text": " If the count stored in <code>countBuffer</code> is greater than <code>1</code>, <span class=\"eq\">(<code>stride</code> {times} (<code>drawCount</code> - 1) + <code>offset</code> + <code>sizeof</code>(<code>VkDrawIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBuffer-00517",\r
+ "text": " The count stored in <code>countBuffer</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDrawIndirectCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00518",\r
+ "text": " Every input attachment used by the current subpass <strong class=\"purple\">must</strong> be bound to the pipeline via a descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00519",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00520",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00521",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00522",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-00523",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-linearTilingFeatures-00524",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-None-01502",\r
+ "text": " Image subresources used as attachments in the current render pass <strong class=\"purple\">must</strong> not be accessed in any way other than as an attachment by this command."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-countBuffer-parameter",\r
+ "text": " <code>countBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commonparent",\r
+ "text": " Each of <code>buffer</code>, <code>commandBuffer</code>, and <code>countBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_AMD_draw_indirect_count)+(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-maxMultiviewInstanceIndex-00525",\r
+ "text": " If the draw is recorded in a render pass instance with multiview enabled, the maximum instance index <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>::<code>maxMultiviewInstanceIndex</code>."\r
+ }\r
+ ],\r
+ "(VK_AMD_draw_indirect_count)+(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commandBuffer-01859",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commandBuffer-01860",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-commandBuffer-01861",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the framebuffer-space pipeline stages in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ],\r
+ "(VK_AMD_draw_indirect_count)+(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndirectCountAMD-sampleLocationsEnable-01515",\r
+ "text": " If the bound graphics pipeline was created with <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>::<code>sampleLocationsEnable</code> set to <code>VK_TRUE</code> and the current subpass has a depth/stencil attachment, then that attachment <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> bit set"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDrawIndexedIndirect": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-buffer-00526",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-buffer-01665",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-offset-00527",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-drawCount-00528",\r
+ "text": " If <code>drawCount</code> is greater than <code>1</code>, <code>stride</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code> and <strong class=\"purple\">must</strong> be greater than or equal to <code>sizeof</code>(<code>VkDrawIndexedIndirectCommand</code>)"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-drawCount-00529",\r
+ "text": " If the <a href=\"#features-features-multiDrawIndirect\">multi-draw indirect</a> feature is not enabled, <code>drawCount</code> <strong class=\"purple\">must</strong> be <code>0</code> or <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-firstInstance-00530",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-drawIndirectFirstInstance,drawIndirectFirstInstance&amp;gt;&amp;gt; feature is not enabled, all the <code>firstInstance</code> members of the <code>VkDrawIndexedIndirectCommand</code> structures accessed by this command <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-renderPass-00531",\r
+ "text": " The current render pass <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-subpass-00532",\r
+ "text": " The subpass index of the current render pass <strong class=\"purple\">must</strong> be equal to the <code>subpass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00533",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00534",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00535",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00536",\r
+ "text": " All vertex input bindings accessed via vertex input variables declared in the vertex shader entry point’s interface <strong class=\"purple\">must</strong> have valid buffers bound"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00537",\r
+ "text": " A valid graphics pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00538",\r
+ "text": " If the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> requires any dynamic state, that state <strong class=\"purple\">must</strong> have been set on the current command buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-drawCount-00539",\r
+ "text": " If <code>drawCount</code> is equal to <code>1</code>, <span class=\"eq\">(<code>offset</code> + <code>sizeof</code>(<code>VkDrawIndexedIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-drawCount-00540",\r
+ "text": " If <code>drawCount</code> is greater than <code>1</code>, <span class=\"eq\">(<code>stride</code> {times} (<code>drawCount</code> - 1) + <code>offset</code> + <code>sizeof</code>(<code>VkDrawIndexedIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-drawCount-00541",\r
+ "text": " <code>drawCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDrawIndirectCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00542",\r
+ "text": " Every input attachment used by the current subpass <strong class=\"purple\">must</strong> be bound to the pipeline via a descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00543",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00544",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00545",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00546",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00547",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-linearTilingFeatures-00548",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-01503",\r
+ "text": " Image subresources used as attachments in the current render pass <strong class=\"purple\">must</strong> not be accessed in any way other than as an attachment by this command."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-linearTilingFeatures-00549",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-None-00550",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> not have a <a href=\"#VkImageViewType\">VkImageViewType</a> of <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-maxMultiviewInstanceIndex-00551",\r
+ "text": " If the draw is recorded in a render pass instance with multiview enabled, the maximum instance index <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>::<code>maxMultiviewInstanceIndex</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commandBuffer-01862",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commandBuffer-01863",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-commandBuffer-01864",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the framebuffer-space pipeline stages in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ],\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirect-sampleLocationsEnable-01516",\r
+ "text": " If the bound graphics pipeline was created with <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>::<code>sampleLocationsEnable</code> set to <code>VK_TRUE</code> and the current subpass has a depth/stencil attachment, then that attachment <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> bit set"\r
+ }\r
+ ]\r
+ },\r
+ "VkDrawIndexedIndirectCommand": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDrawIndexedIndirectCommand-None-00552",\r
+ "text": " For a given vertex buffer binding, any attribute data fetched <strong class=\"purple\">must</strong> be entirely contained within the corresponding vertex buffer binding, as described in &amp;lt;&amp;lt;fxvertex-input&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDrawIndexedIndirectCommand-indexSize-00553",\r
+ "text": " <span class=\"eq\">(<code>indexSize</code> * (<code>firstIndex</code> + <code>indexCount</code>) + <code>offset</code>)</span> <strong class=\"purple\">must</strong> be less than or equal to the size of the bound index buffer, with <code>indexSize</code> being based on the type specified by <code>indexType</code>, where the index buffer, <code>indexType</code>, and <code>offset</code> are specified via <code>vkCmdBindIndexBuffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDrawIndexedIndirectCommand-firstInstance-00554",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-drawIndirectFirstInstance,drawIndirectFirstInstance&amp;gt;&amp;gt; feature is not enabled, <code>firstInstance</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDrawIndexedIndirectCountAMD": {\r
+ "(VK_AMD_draw_indirect_count)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-buffer-01666",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-buffer-01667",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-countBuffer-01668",\r
+ "text": " If <code>countBuffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-countBuffer-01669",\r
+ "text": " <code>countBuffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-offset-00555",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-countBufferOffset-00556",\r
+ "text": " <code>countBufferOffset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-stride-00557",\r
+ "text": " <code>stride</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code> and <strong class=\"purple\">must</strong> be greater than or equal to <code>sizeof</code>(<code>VkDrawIndirectCommand</code>)"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-maxDrawCount-00558",\r
+ "text": " If <code>maxDrawCount</code> is greater than or equal to <code>1</code>, <span class=\"eq\">(<code>stride</code> {times} (<code>maxDrawCount</code> - 1) + <code>offset</code> + <code>sizeof</code>(<code>VkDrawIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-firstInstance-00559",\r
+ "text": " If the <a href=\"#features-features-drawIndirectFirstInstance\">drawIndirectFirstInstance</a> feature is not enabled, all the <code>firstInstance</code> members of the <code>VkDrawIndexedIndirectCommand</code> structures accessed by this command <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-renderPass-00560",\r
+ "text": " The current render pass <strong class=\"purple\">must</strong> be &amp;lt;&amp;lt;renderpass-compatibility,compatible&amp;gt;&amp;gt; with the <code>renderPass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-subpass-00561",\r
+ "text": " The subpass index of the current render pass <strong class=\"purple\">must</strong> be equal to the <code>subpass</code> member of the <code>VkGraphicsPipelineCreateInfo</code> structure specified when creating the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00562",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00563",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00564",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00565",\r
+ "text": " All vertex input bindings accessed via vertex input variables declared in the vertex shader entry point’s interface <strong class=\"purple\">must</strong> have valid buffers bound"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00566",\r
+ "text": " A valid graphics pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00567",\r
+ "text": " If the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> requires any dynamic state, that state <strong class=\"purple\">must</strong> have been set on the current command buffer"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-countBuffer-00568",\r
+ "text": " If count stored in <code>countBuffer</code> is equal to <code>1</code>, <span class=\"eq\">(<code>offset</code> + <code>sizeof</code>(<code>VkDrawIndexedIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-countBuffer-00569",\r
+ "text": " If count stored in <code>countBuffer</code> is greater than <code>1</code>, <span class=\"eq\">(<code>stride</code> {times} (<code>drawCount</code> - 1) + <code>offset</code> + <code>sizeof</code>(<code>VkDrawIndexedIndirectCommand</code>))</span> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-drawCount-00570",\r
+ "text": " <code>drawCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxDrawIndirectCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00571",\r
+ "text": " Every input attachment used by the current subpass <strong class=\"purple\">must</strong> be bound to the pipeline via a descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00572",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00573",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00574",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00575",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-00576",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-linearTilingFeatures-00577",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-None-01504",\r
+ "text": " Image subresources used as attachments in the current render pass <strong class=\"purple\">must</strong> not be accessed in any way other than as an attachment by this command."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-countBuffer-parameter",\r
+ "text": " <code>countBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commonparent",\r
+ "text": " Each of <code>buffer</code>, <code>commandBuffer</code>, and <code>countBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_AMD_draw_indirect_count)+(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-maxMultiviewInstanceIndex-00578",\r
+ "text": " If the draw is recorded in a render pass instance with multiview enabled, the maximum instance index <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceMultiviewProperties\">VkPhysicalDeviceMultiviewProperties</a>::<code>maxMultiviewInstanceIndex</code>."\r
+ }\r
+ ],\r
+ "(VK_AMD_draw_indirect_count)+(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commandBuffer-01865",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commandBuffer-01866",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-commandBuffer-01867",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the framebuffer-space pipeline stages in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_GRAPHICS</code> reads from or writes to any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ],\r
+ "(VK_AMD_draw_indirect_count)+(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDrawIndexedIndirectCountAMD-sampleLocationsEnable-01517",\r
+ "text": " If the bound graphics pipeline was created with <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>::<code>sampleLocationsEnable</code> set to <code>VK_TRUE</code> and the current subpass has a depth/stencil attachment, then that attachment <strong class=\"purple\">must</strong> have been created with the <code>VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT</code> bit set"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineVertexInputStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-vertexBindingDescriptionCount-00613",\r
+ "text": " <code>vertexBindingDescriptionCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindings</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-vertexAttributeDescriptionCount-00614",\r
+ "text": " <code>vertexAttributeDescriptionCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputAttributes</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-binding-00615",\r
+ "text": " For every <code>binding</code> specified by each element of <code>pVertexAttributeDescriptions</code>, a <code>VkVertexInputBindingDescription</code> <strong class=\"purple\">must</strong> exist in <code>pVertexBindingDescriptions</code> with the same value of <code>binding</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-pVertexBindingDescriptions-00616",\r
+ "text": " All elements of <code>pVertexBindingDescriptions</code> <strong class=\"purple\">must</strong> describe distinct binding numbers"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-pVertexAttributeDescriptions-00617",\r
+ "text": " All elements of <code>pVertexAttributeDescriptions</code> <strong class=\"purple\">must</strong> describe distinct attribute locations"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineVertexInputDivisorStateCreateInfoEXT\">VkPipelineVertexInputDivisorStateCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-pVertexBindingDescriptions-parameter",\r
+ "text": " If <code>vertexBindingDescriptionCount</code> is not <code>0</code>, <code>pVertexBindingDescriptions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>vertexBindingDescriptionCount</code> valid <code>VkVertexInputBindingDescription</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputStateCreateInfo-pVertexAttributeDescriptions-parameter",\r
+ "text": " If <code>vertexAttributeDescriptionCount</code> is not <code>0</code>, <code>pVertexAttributeDescriptions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>vertexAttributeDescriptionCount</code> valid <code>VkVertexInputAttributeDescription</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkVertexInputBindingDescription": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkVertexInputBindingDescription-binding-00618",\r
+ "text": " <code>binding</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindings</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputBindingDescription-stride-00619",\r
+ "text": " <code>stride</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindingStride</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputBindingDescription-inputRate-parameter",\r
+ "text": " <code>inputRate</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkVertexInputRate\">VkVertexInputRate</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkVertexInputAttributeDescription": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkVertexInputAttributeDescription-location-00620",\r
+ "text": " <code>location</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputAttributes</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputAttributeDescription-binding-00621",\r
+ "text": " <code>binding</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindings</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputAttributeDescription-offset-00622",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputAttributeOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputAttributeDescription-format-00623",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be allowed as a vertex buffer format, as specified by the <code>VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT</code> flag in <code>VkFormatProperties</code>::<code>bufferFeatures</code> returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputAttributeDescription-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBindVertexBuffers": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-firstBinding-00624",\r
+ "text": " <code>firstBinding</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindings</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-firstBinding-00625",\r
+ "text": " The sum of <code>firstBinding</code> and <code>bindingCount</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindings</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-pOffsets-00626",\r
+ "text": " All elements of <code>pOffsets</code> <strong class=\"purple\">must</strong> be less than the size of the corresponding element in <code>pBuffers</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-pBuffers-00627",\r
+ "text": " All elements of <code>pBuffers</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_VERTEX_BUFFER_BIT</code> flag"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-pBuffers-00628",\r
+ "text": " Each element of <code>pBuffers</code> that is non-sparse <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-pBuffers-parameter",\r
+ "text": " <code>pBuffers</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindingCount</code> valid <code>VkBuffer</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-pOffsets-parameter",\r
+ "text": " <code>pOffsets</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindingCount</code> <code>VkDeviceSize</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-bindingCount-arraylength",\r
+ "text": " <code>bindingCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBindVertexBuffers-commonparent",\r
+ "text": " Both of <code>commandBuffer</code>, and the elements of <code>pBuffers</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineVertexInputDivisorStateCreateInfoEXT": {\r
+ "(VK_EXT_vertex_attribute_divisor)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputDivisorStateCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputDivisorStateCreateInfoEXT-pVertexBindingDivisors-parameter",\r
+ "text": " <code>pVertexBindingDivisors</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>vertexBindingDivisorCount</code> <code>VkVertexInputBindingDivisorDescriptionEXT</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineVertexInputDivisorStateCreateInfoEXT-vertexBindingDivisorCount-arraylength",\r
+ "text": " <code>vertexBindingDivisorCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkVertexInputBindingDivisorDescriptionEXT": {\r
+ "(VK_EXT_vertex_attribute_divisor)": [\r
+ {\r
+ "vuid": "VUID-VkVertexInputBindingDivisorDescriptionEXT-binding-01869",\r
+ "text": " <code>binding</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxVertexInputBindings</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputBindingDivisorDescriptionEXT-divisor-01870",\r
+ "text": " <code>divisor</code> <strong class=\"purple\">must</strong> be a value between <code>0</code> and <code>VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT</code>::<code>maxVertexAttribDivisor</code>, inclusive."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkVertexInputBindingDivisorDescriptionEXT-inputRate-01871",\r
+ "text": " <a href=\"#VkVertexInputBindingDescription\">VkVertexInputBindingDescription</a>::<code>inputRate</code> <strong class=\"purple\">must</strong> be of type <code>VK_VERTEX_INPUT_RATE_INSTANCE</code> for this <code>binding</code>."\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineTessellationStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineTessellationStateCreateInfo-patchControlPoints-01214",\r
+ "text": " <code>patchControlPoints</code> <strong class=\"purple\">must</strong> be greater than zero and less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxTessellationPatchSize</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineTessellationStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineTessellationStateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineTessellationDomainOriginStateCreateInfo\">VkPipelineTessellationDomainOriginStateCreateInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineTessellationStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineTessellationDomainOriginStateCreateInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineTessellationDomainOriginStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineTessellationDomainOriginStateCreateInfo-domainOrigin-parameter",\r
+ "text": " <code>domainOrigin</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkTessellationDomainOrigin\">VkTessellationDomainOrigin</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineViewportSwizzleStateCreateInfoNV": {\r
+ "(VK_NV_viewport_swizzle)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportSwizzleStateCreateInfoNV-viewportCount-01215",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> match the <code>viewportCount</code> set in <code>VkPipelineViewportStateCreateInfo</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportSwizzleStateCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportSwizzleStateCreateInfoNV-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportSwizzleStateCreateInfoNV-viewportCount-arraylength",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkViewportSwizzleNV": {\r
+ "(VK_NV_viewport_swizzle)": [\r
+ {\r
+ "vuid": "VUID-VkViewportSwizzleNV-x-parameter",\r
+ "text": " <code>x</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkViewportCoordinateSwizzleNV\">VkViewportCoordinateSwizzleNV</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewportSwizzleNV-y-parameter",\r
+ "text": " <code>y</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkViewportCoordinateSwizzleNV\">VkViewportCoordinateSwizzleNV</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewportSwizzleNV-z-parameter",\r
+ "text": " <code>z</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkViewportCoordinateSwizzleNV\">VkViewportCoordinateSwizzleNV</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewportSwizzleNV-w-parameter",\r
+ "text": " <code>w</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkViewportCoordinateSwizzleNV\">VkViewportCoordinateSwizzleNV</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineViewportWScalingStateCreateInfoNV": {\r
+ "(VK_NV_clip_space_w_scaling)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportWScalingStateCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportWScalingStateCreateInfoNV-viewportCount-arraylength",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetViewportWScalingNV": {\r
+ "(VK_NV_clip_space_w_scaling)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-None-01322",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-firstViewport-01323",\r
+ "text": " <code>firstViewport</code> <strong class=\"purple\">must</strong> be less than <a href=\"#VkPhysicalDeviceLimits\">VkPhysicalDeviceLimits</a>::<code>maxViewports</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-firstViewport-01324",\r
+ "text": " The sum of <code>firstViewport</code> and <code>viewportCount</code> <strong class=\"purple\">must</strong> be between <code>1</code> and <a href=\"#VkPhysicalDeviceLimits\">VkPhysicalDeviceLimits</a>::<code>maxViewports</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-pViewportWScalings-parameter",\r
+ "text": " <code>pViewportWScalings</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>viewportCount</code> <code>VkViewportWScalingNV</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewportWScalingNV-viewportCount-arraylength",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineViewportStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-viewportCount-01216",\r
+ "text": " If the <a href=\"#features-features-multiViewport\">multiple viewports</a> feature is not enabled, <code>viewportCount</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-scissorCount-01217",\r
+ "text": " If the <a href=\"#features-features-multiViewport\">multiple viewports</a> feature is not enabled, <code>scissorCount</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-viewportCount-01218",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> be between <code>1</code> and <code>VkPhysicalDeviceLimits</code>::<code>maxViewports</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-scissorCount-01219",\r
+ "text": " <code>scissorCount</code> <strong class=\"purple\">must</strong> be between <code>1</code> and <code>VkPhysicalDeviceLimits</code>::<code>maxViewports</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-scissorCount-01220",\r
+ "text": " <code>scissorCount</code> and <code>viewportCount</code> <strong class=\"purple\">must</strong> be identical"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineViewportSwizzleStateCreateInfoNV\">VkPipelineViewportSwizzleStateCreateInfoNV</a> or <a href=\"#VkPipelineViewportWScalingStateCreateInfoNV\">VkPipelineViewportWScalingStateCreateInfoNV</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-viewportCount-arraylength",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-scissorCount-arraylength",\r
+ "text": " <code>scissorCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ],\r
+ "(VK_NV_clip_space_w_scaling)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineViewportStateCreateInfo-viewportWScalingEnable-01726",\r
+ "text": " If the <code>viewportWScalingEnable</code> member of a <a href=\"#VkPipelineViewportWScalingStateCreateInfoNV\">VkPipelineViewportWScalingStateCreateInfoNV</a> structure chained to the <code>pNext</code> chain is <code>VK_TRUE</code>, the <code>viewportCount</code> member of the <a href=\"#VkPipelineViewportWScalingStateCreateInfoNV\">VkPipelineViewportWScalingStateCreateInfoNV</a> structure <strong class=\"purple\">must</strong> be equal to <code>viewportCount</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetViewport": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-None-01221",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_VIEWPORT</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-firstViewport-01222",\r
+ "text": " <code>firstViewport</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxViewports</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-firstViewport-01223",\r
+ "text": " The sum of <code>firstViewport</code> and <code>viewportCount</code> <strong class=\"purple\">must</strong> be between <code>1</code> and <code>VkPhysicalDeviceLimits</code>::<code>maxViewports</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-firstViewport-01224",\r
+ "text": " If the <a href=\"#features-features-multiViewport\">multiple viewports</a> feature is not enabled, <code>firstViewport</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-viewportCount-01225",\r
+ "text": " If the <a href=\"#features-features-multiViewport\">multiple viewports</a> feature is not enabled, <code>viewportCount</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-pViewports-parameter",\r
+ "text": " <code>pViewports</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>viewportCount</code> <code>VkViewport</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetViewport-viewportCount-arraylength",\r
+ "text": " <code>viewportCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkViewport": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkViewport-width-01770",\r
+ "text": " <code>width</code> <strong class=\"purple\">must</strong> be greater than <code>0.0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-width-01771",\r
+ "text": " <code>width</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxViewportDimensions</code>[0]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-height-01773",\r
+ "text": " The absolute value of <code>height</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxViewportDimensions</code>[1]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-x-01774",\r
+ "text": " <code>x</code> <strong class=\"purple\">must</strong> be greater than or equal to <code>viewportBoundsRange</code>[0]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-x-01232",\r
+ "text": " <span class=\"eq\">(<code>x</code> + <code>width</code>)</span> <strong class=\"purple\">must</strong> be less than or equal to <code>viewportBoundsRange</code>[1]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-y-01775",\r
+ "text": " <code>y</code> <strong class=\"purple\">must</strong> be greater than or equal to <code>viewportBoundsRange</code>[0]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-y-01233",\r
+ "text": " <span class=\"eq\">(<code>y</code> + <code>height</code>)</span> <strong class=\"purple\">must</strong> be less than or equal to <code>viewportBoundsRange</code>[1]"\r
+ }\r
+ ],\r
+ "!(VK_VERSION_1_1,VK_KHR_maintenance1,VK_AMD_negative_viewport_height)": [\r
+ {\r
+ "vuid": "VUID-VkViewport-height-01772",\r
+ "text": " <code>height</code> <strong class=\"purple\">must</strong> be greater than <code>0.0</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance1,VK_AMD_negative_viewport_height)": [\r
+ {\r
+ "vuid": "VUID-VkViewport-y-01776",\r
+ "text": " <code>y</code> <strong class=\"purple\">must</strong> be less than or equal to <code>viewportBoundsRange</code>[1]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-y-01777",\r
+ "text": " <span class=\"eq\">(<code>y</code> + <code>height</code>)</span> <strong class=\"purple\">must</strong> be greater than or equal to <code>viewportBoundsRange</code>[0]"\r
+ }\r
+ ],\r
+ "(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-VkViewport-minDepth-01234",\r
+ "text": " Unless <code><a href=\"#VK_EXT_depth_range_unrestricted\">VK_EXT_depth_range_unrestricted</a></code> extension is enabled <code>minDepth</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-maxDepth-01235",\r
+ "text": " Unless <code><a href=\"#VK_EXT_depth_range_unrestricted\">VK_EXT_depth_range_unrestricted</a></code> extension is enabled <code>maxDepth</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ],\r
+ "!(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-VkViewport-minDepth-01234",\r
+ "text": " <code>minDepth</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViewport-maxDepth-01235",\r
+ "text": " <code>maxDepth</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineRasterizationStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-depthClampEnable-00782",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-depthClamp,depth clamping&amp;gt;&amp;gt; feature is not enabled, <code>depthClampEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineRasterizationConservativeStateCreateInfoEXT\">VkPipelineRasterizationConservativeStateCreateInfoEXT</a> or <a href=\"#VkPipelineRasterizationStateRasterizationOrderAMD\">VkPipelineRasterizationStateRasterizationOrderAMD</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-polygonMode-parameter",\r
+ "text": " <code>polygonMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPolygonMode\">VkPolygonMode</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-cullMode-parameter",\r
+ "text": " <code>cullMode</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkCullModeFlagBits\">VkCullModeFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-frontFace-parameter",\r
+ "text": " <code>frontFace</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFrontFace\">VkFrontFace</a> value"\r
+ }\r
+ ],\r
+ "!(VK_NV_fill_rectangle)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-polygonMode-01413",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-fillModeNonSolid,non-solid fill modes&amp;gt;&amp;gt; feature is not enabled, <code>polygonMode</code> <strong class=\"purple\">must</strong> be <code>VK_POLYGON_MODE_FILL</code>"\r
+ }\r
+ ],\r
+ "(VK_NV_fill_rectangle)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-polygonMode-01507",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-fillModeNonSolid,non-solid fill modes&amp;gt;&amp;gt; feature is not enabled, <code>polygonMode</code> <strong class=\"purple\">must</strong> be <code>VK_POLYGON_MODE_FILL</code> or <code>VK_POLYGON_MODE_FILL_RECTANGLE_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateCreateInfo-polygonMode-01414",\r
+ "text": " If the <code><a href=\"#VK_NV_fill_rectangle\">VK_NV_fill_rectangle</a></code> extension is not enabled, <code>polygonMode</code> <strong class=\"purple\">must</strong> not be <code>VK_POLYGON_MODE_FILL_RECTANGLE_NV</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineMultisampleStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-sampleShadingEnable-00784",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sampleRateShading,sample rate shading&amp;gt;&amp;gt; feature is not enabled, <code>sampleShadingEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-alphaToOneEnable-00785",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-alphaToOne,alpha to one&amp;gt;&amp;gt; feature is not enabled, <code>alphaToOneEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-minSampleShading-00786",\r
+ "text": " <code>minSampleShading</code> <strong class=\"purple\">must</strong> be in the range <span class=\"eq\">[0,1]</span>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineCoverageModulationStateCreateInfoNV\">VkPipelineCoverageModulationStateCreateInfoNV</a>, <a href=\"#VkPipelineCoverageToColorStateCreateInfoNV\">VkPipelineCoverageToColorStateCreateInfoNV</a>, or <a href=\"#VkPipelineSampleLocationsStateCreateInfoEXT\">VkPipelineSampleLocationsStateCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-rasterizationSamples-parameter",\r
+ "text": " <code>rasterizationSamples</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-pSampleMask-parameter",\r
+ "text": " If <code>pSampleMask</code> is not <code>NULL</code>, <code>pSampleMask</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of \\(\\lceil{\\mathit{rasterizationSamples} \\over 32}\\rceil\\) <code>VkSampleMask</code> values"\r
+ }\r
+ ],\r
+ "(VK_NV_framebuffer_mixed_samples)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineMultisampleStateCreateInfo-rasterizationSamples-01415",\r
+ "text": " If the subpass has any color attachments and <code>rasterizationSamples</code> is greater than the number of color samples, then <code>sampleShadingEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineRasterizationStateRasterizationOrderAMD": {\r
+ "(VK_AMD_rasterization_order)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateRasterizationOrderAMD-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationStateRasterizationOrderAMD-rasterizationOrder-parameter",\r
+ "text": " <code>rasterizationOrder</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkRasterizationOrderAMD\">VkRasterizationOrderAMD</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineSampleLocationsStateCreateInfoEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineSampleLocationsStateCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineSampleLocationsStateCreateInfoEXT-sampleLocationsInfo-parameter",\r
+ "text": " <code>sampleLocationsInfo</code> <strong class=\"purple\">must</strong> be a valid <code>VkSampleLocationsInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkSampleLocationsInfoEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkSampleLocationsInfoEXT-sampleLocationsPerPixel-01526",\r
+ "text": " <code>sampleLocationsPerPixel</code> <strong class=\"purple\">must</strong> be a bit value that is set in <a href=\"#VkPhysicalDeviceSampleLocationsPropertiesEXT\">VkPhysicalDeviceSampleLocationsPropertiesEXT</a>::<code>sampleLocationSampleCounts</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSampleLocationsInfoEXT-sampleLocationsCount-01527",\r
+ "text": " <code>sampleLocationsCount</code> <strong class=\"purple\">must</strong> equal <span class=\"eq\"><code>sampleLocationsPerPixel</code> {times} <code>sampleLocationGridSize.width</code> {times} <code>sampleLocationGridSize.height</code></span>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSampleLocationsInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSampleLocationsInfoEXT-sampleLocationsPerPixel-parameter",\r
+ "text": " <code>sampleLocationsPerPixel</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSampleLocationsInfoEXT-pSampleLocations-parameter",\r
+ "text": " <code>pSampleLocations</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>sampleLocationsCount</code> <code>VkSampleLocationEXT</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSampleLocationsInfoEXT-sampleLocationsCount-arraylength",\r
+ "text": " <code>sampleLocationsCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetSampleLocationsEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-None-01528",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-sampleLocationsPerPixel-01529",\r
+ "text": " The <code>sampleLocationsPerPixel</code> member of <code>pSampleLocationsInfo</code> <strong class=\"purple\">must</strong> equal the <code>rasterizationSamples</code> member of the <a href=\"#VkPipelineMultisampleStateCreateInfo\">VkPipelineMultisampleStateCreateInfo</a> structure the bound graphics pipeline has been created with"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-variableSampleLocations-01530",\r
+ "text": " If <a href=\"#VkPhysicalDeviceSampleLocationsPropertiesEXT\">VkPhysicalDeviceSampleLocationsPropertiesEXT</a>::<code>variableSampleLocations</code> is <code>VK_FALSE</code> then the current render pass <strong class=\"purple\">must</strong> have been begun by specifying a <a href=\"#VkRenderPassSampleLocationsBeginInfoEXT\">VkRenderPassSampleLocationsBeginInfoEXT</a> structure whose <code>pPostSubpassSampleLocations</code> member contains an element with a <code>subpassIndex</code> matching the current subpass index and the <code>sampleLocationsInfo</code> member of that element <strong class=\"purple\">must</strong> match the sample locations state pointed to by <code>pSampleLocationsInfo</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-pSampleLocationsInfo-parameter",\r
+ "text": " <code>pSampleLocationsInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSampleLocationsInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetSampleLocationsEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetLineWidth": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetLineWidth-None-00787",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_LINE_WIDTH</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetLineWidth-lineWidth-00788",\r
+ "text": " If the <a href=\"#features-features-wideLines\">wide lines</a> feature is not enabled, <code>lineWidth</code> <strong class=\"purple\">must</strong> be <code>1.0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetLineWidth-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetLineWidth-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetLineWidth-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetDepthBias": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBias-None-00789",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_DEPTH_BIAS</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBias-depthBiasClamp-00790",\r
+ "text": " If the <a href=\"#features-features-depthBiasClamp\">depth bias clamping</a> feature is not enabled, <code>depthBiasClamp</code> <strong class=\"purple\">must</strong> be <code>0.0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBias-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBias-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBias-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineRasterizationConservativeStateCreateInfoEXT": {\r
+ "(VK_EXT_conservative_rasterization)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationConservativeStateCreateInfoEXT-extraPrimitiveOverestimationSize-01769",\r
+ "text": " <code>extraPrimitiveOverestimationSize</code> <strong class=\"purple\">must</strong> be in the range of <code>0.0</code> to <code>VkPhysicalDeviceConservativeRasterizationPropertiesEXT</code>::<code>maxExtraPrimitiveOverestimationSize</code> inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationConservativeStateCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationConservativeStateCreateInfoEXT-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineRasterizationConservativeStateCreateInfoEXT-conservativeRasterizationMode-parameter",\r
+ "text": " <code>conservativeRasterizationMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkConservativeRasterizationModeEXT\">VkConservativeRasterizationModeEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineDiscardRectangleStateCreateInfoEXT": {\r
+ "(VK_EXT_discard_rectangles)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineDiscardRectangleStateCreateInfoEXT-discardRectangleCount-00582",\r
+ "text": " <code>discardRectangleCount</code> <strong class=\"purple\">must</strong> be between <code>0</code> and <code>VkPhysicalDeviceDiscardRectanglePropertiesEXT</code>::<code>maxDiscardRectangles</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDiscardRectangleStateCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDiscardRectangleStateCreateInfoEXT-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDiscardRectangleStateCreateInfoEXT-discardRectangleMode-parameter",\r
+ "text": " <code>discardRectangleMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDiscardRectangleModeEXT\">VkDiscardRectangleModeEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetDiscardRectangleEXT": {\r
+ "(VK_EXT_discard_rectangles)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-None-00583",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_DISCARD_RECTANGLE_EXT</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-firstDiscardRectangle-00585",\r
+ "text": " The sum of <code>firstDiscardRectangle</code> and <code>discardRectangleCount</code> <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceDiscardRectanglePropertiesEXT\">VkPhysicalDeviceDiscardRectanglePropertiesEXT</a>::<code>maxDiscardRectangles</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-x-00587",\r
+ "text": " The <code>x</code> and <code>y</code> member of <code>offset</code> in each <a href=\"#VkRect2D\">VkRect2D</a> element of <code>pDiscardRectangles</code> <strong class=\"purple\">must</strong> be greater than or equal to <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-offset-00588",\r
+ "text": " Evaluation of <span class=\"eq\">(<code>offset.x</code> + <code>extent.width</code>)</span> in each <a href=\"#VkRect2D\">VkRect2D</a> element of <code>pDiscardRectangles</code> <strong class=\"purple\">must</strong> not cause a signed integer addition overflow"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-offset-00589",\r
+ "text": " Evaluation of <span class=\"eq\">(<code>offset.y</code> + <code>extent.height</code>)</span> in each <a href=\"#VkRect2D\">VkRect2D</a> element of <code>pDiscardRectangles</code> <strong class=\"purple\">must</strong> not cause a signed integer addition overflow"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-pDiscardRectangles-parameter",\r
+ "text": " <code>pDiscardRectangles</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>discardRectangleCount</code> <code>VkRect2D</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDiscardRectangleEXT-discardRectangleCount-arraylength",\r
+ "text": " <code>discardRectangleCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetScissor": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-None-00590",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_SCISSOR</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-firstScissor-00591",\r
+ "text": " <code>firstScissor</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxViewports</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-firstScissor-00592",\r
+ "text": " The sum of <code>firstScissor</code> and <code>scissorCount</code> <strong class=\"purple\">must</strong> be between <code>1</code> and <code>VkPhysicalDeviceLimits</code>::<code>maxViewports</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-firstScissor-00593",\r
+ "text": " If the <a href=\"#features-features-multiViewport\">multiple viewports</a> feature is not enabled, <code>firstScissor</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-scissorCount-00594",\r
+ "text": " If the <a href=\"#features-features-multiViewport\">multiple viewports</a> feature is not enabled, <code>scissorCount</code> <strong class=\"purple\">must</strong> be <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-x-00595",\r
+ "text": " The <code>x</code> and <code>y</code> members of <code>offset</code> <strong class=\"purple\">must</strong> be greater than or equal to <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-offset-00596",\r
+ "text": " Evaluation of <span class=\"eq\">(<code>offset.x</code> + <code>extent.width</code>)</span> <strong class=\"purple\">must</strong> not cause a signed integer addition overflow"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-offset-00597",\r
+ "text": " Evaluation of <span class=\"eq\">(<code>offset.y</code> + <code>extent.height</code>)</span> <strong class=\"purple\">must</strong> not cause a signed integer addition overflow"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-pScissors-parameter",\r
+ "text": " <code>pScissors</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>scissorCount</code> <code>VkRect2D</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetScissor-scissorCount-arraylength",\r
+ "text": " <code>scissorCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineDepthStencilStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-depthBoundsTestEnable-00598",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-depthBounds,depth bounds testing&amp;gt;&amp;gt; feature is not enabled, <code>depthBoundsTestEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-depthCompareOp-parameter",\r
+ "text": " <code>depthCompareOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkCompareOp\">VkCompareOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-front-parameter",\r
+ "text": " <code>front</code> <strong class=\"purple\">must</strong> be a valid <code>VkStencilOpState</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineDepthStencilStateCreateInfo-back-parameter",\r
+ "text": " <code>back</code> <strong class=\"purple\">must</strong> be a valid <code>VkStencilOpState</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetDepthBounds": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-None-00599",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_DEPTH_BOUNDS</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ],\r
+ "(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-minDepthBounds-00600",\r
+ "text": " Unless the <code><a href=\"#VK_EXT_depth_range_unrestricted\">VK_EXT_depth_range_unrestricted</a></code> extension is enabled <code>minDepthBounds</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-maxDepthBounds-00601",\r
+ "text": " Unless the <code><a href=\"#VK_EXT_depth_range_unrestricted\">VK_EXT_depth_range_unrestricted</a></code> extension is enabled <code>maxDepthBounds</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ],\r
+ "!(VK_EXT_depth_range_unrestricted)": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-minDepthBounds-00600",\r
+ "text": " <code>minDepthBounds</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetDepthBounds-maxDepthBounds-00601",\r
+ "text": " <code>maxDepthBounds</code> <strong class=\"purple\">must</strong> be between <code>0.0</code> and <code>1.0</code>, inclusive"\r
+ }\r
+ ]\r
+ },\r
+ "VkStencilOpState": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkStencilOpState-failOp-parameter",\r
+ "text": " <code>failOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkStencilOp\">VkStencilOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkStencilOpState-passOp-parameter",\r
+ "text": " <code>passOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkStencilOp\">VkStencilOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkStencilOpState-depthFailOp-parameter",\r
+ "text": " <code>depthFailOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkStencilOp\">VkStencilOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkStencilOpState-compareOp-parameter",\r
+ "text": " <code>compareOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkCompareOp\">VkCompareOp</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetStencilCompareMask": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilCompareMask-None-00602",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilCompareMask-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilCompareMask-faceMask-parameter",\r
+ "text": " <code>faceMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkStencilFaceFlagBits\">VkStencilFaceFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilCompareMask-faceMask-requiredbitmask",\r
+ "text": " <code>faceMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilCompareMask-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilCompareMask-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetStencilWriteMask": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilWriteMask-None-00603",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_STENCIL_WRITE_MASK</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilWriteMask-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilWriteMask-faceMask-parameter",\r
+ "text": " <code>faceMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkStencilFaceFlagBits\">VkStencilFaceFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilWriteMask-faceMask-requiredbitmask",\r
+ "text": " <code>faceMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilWriteMask-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilWriteMask-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetStencilReference": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilReference-None-00604",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_STENCIL_REFERENCE</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilReference-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilReference-faceMask-parameter",\r
+ "text": " <code>faceMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkStencilFaceFlagBits\">VkStencilFaceFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilReference-faceMask-requiredbitmask",\r
+ "text": " <code>faceMask</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilReference-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetStencilReference-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineCoverageToColorStateCreateInfoNV": {\r
+ "(VK_NV_fragment_coverage_to_color)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageToColorStateCreateInfoNV-coverageToColorEnable-01404",\r
+ "text": " If <code>coverageToColorEnable</code> is <code>VK_TRUE</code>, then the render pass subpass indicated by <a href=\"#VkGraphicsPipelineCreateInfo\">VkGraphicsPipelineCreateInfo</a>::<code>renderPass</code> and <a href=\"#VkGraphicsPipelineCreateInfo\">VkGraphicsPipelineCreateInfo</a>::<code>subpass</code> <strong class=\"purple\">must</strong> have a color attachment at the location selected by <code>coverageToColorLocation</code>, with a <a href=\"#VkFormat\">VkFormat</a> of <code>VK_FORMAT_R8_UINT</code>, <code>VK_FORMAT_R8_SINT</code>, <code>VK_FORMAT_R16_UINT</code>, <code>VK_FORMAT_R16_SINT</code>, <code>VK_FORMAT_R32_UINT</code>, or <code>VK_FORMAT_R32_SINT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageToColorStateCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageToColorStateCreateInfoNV-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineCoverageModulationStateCreateInfoNV": {\r
+ "(VK_NV_framebuffer_mixed_samples)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageModulationStateCreateInfoNV-coverageModulationTableEnable-01405",\r
+ "text": " If <code>coverageModulationTableEnable</code> is <code>VK_TRUE</code>, <code>coverageModulationTableCount</code> <strong class=\"purple\">must</strong> be equal to the number of rasterization samples divided by the number of color samples in the subpass."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageModulationStateCreateInfoNV-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageModulationStateCreateInfoNV-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageModulationStateCreateInfoNV-coverageModulationMode-parameter",\r
+ "text": " <code>coverageModulationMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkCoverageModulationModeNV\">VkCoverageModulationModeNV</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineCoverageModulationStateCreateInfoNV-coverageModulationTableCount-arraylength",\r
+ "text": " <code>coverageModulationTableCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineColorBlendStateCreateInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-pAttachments-00605",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-independentBlend,independent blending&amp;gt;&amp;gt; feature is not enabled, all elements of <code>pAttachments</code> <strong class=\"purple\">must</strong> be identical"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-logicOpEnable-00606",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-logicOp,logic operations&amp;gt;&amp;gt; feature is not enabled, <code>logicOpEnable</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-logicOpEnable-00607",\r
+ "text": " If <code>logicOpEnable</code> is <code>VK_TRUE</code>, <code>logicOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkLogicOp\">VkLogicOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPipelineColorBlendAdvancedStateCreateInfoEXT\">VkPipelineColorBlendAdvancedStateCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendStateCreateInfo-pAttachments-parameter",\r
+ "text": " If <code>attachmentCount</code> is not <code>0</code>, <code>pAttachments</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>attachmentCount</code> valid <code>VkPipelineColorBlendAttachmentState</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineColorBlendAttachmentState": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-srcColorBlendFactor-00608",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-dualSrcBlend,dual source blending&amp;gt;&amp;gt; feature is not enabled, <code>srcColorBlendFactor</code> <strong class=\"purple\">must</strong> not be <code>VK_BLEND_FACTOR_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_SRC1_ALPHA</code>, or <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-dstColorBlendFactor-00609",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-dualSrcBlend,dual source blending&amp;gt;&amp;gt; feature is not enabled, <code>dstColorBlendFactor</code> <strong class=\"purple\">must</strong> not be <code>VK_BLEND_FACTOR_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_SRC1_ALPHA</code>, or <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-srcAlphaBlendFactor-00610",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-dualSrcBlend,dual source blending&amp;gt;&amp;gt; feature is not enabled, <code>srcAlphaBlendFactor</code> <strong class=\"purple\">must</strong> not be <code>VK_BLEND_FACTOR_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_SRC1_ALPHA</code>, or <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-dstAlphaBlendFactor-00611",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-dualSrcBlend,dual source blending&amp;gt;&amp;gt; feature is not enabled, <code>dstAlphaBlendFactor</code> <strong class=\"purple\">must</strong> not be <code>VK_BLEND_FACTOR_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR</code>, <code>VK_BLEND_FACTOR_SRC1_ALPHA</code>, or <code>VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-srcColorBlendFactor-parameter",\r
+ "text": " <code>srcColorBlendFactor</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendFactor\">VkBlendFactor</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-dstColorBlendFactor-parameter",\r
+ "text": " <code>dstColorBlendFactor</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendFactor\">VkBlendFactor</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-colorBlendOp-parameter",\r
+ "text": " <code>colorBlendOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendOp\">VkBlendOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-srcAlphaBlendFactor-parameter",\r
+ "text": " <code>srcAlphaBlendFactor</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendFactor\">VkBlendFactor</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-dstAlphaBlendFactor-parameter",\r
+ "text": " <code>dstAlphaBlendFactor</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendFactor\">VkBlendFactor</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-alphaBlendOp-parameter",\r
+ "text": " <code>alphaBlendOp</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendOp\">VkBlendOp</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-colorWriteMask-parameter",\r
+ "text": " <code>colorWriteMask</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkColorComponentFlagBits\">VkColorComponentFlagBits</a> values"\r
+ }\r
+ ],\r
+ "(VK_EXT_blend_operation_advanced)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-colorBlendOp-01406",\r
+ "text": " If either of <code>colorBlendOp</code> or <code>alphaBlendOp</code> is an &amp;lt;&amp;lt;framebuffer-blend-advanced,advanced blend operation&amp;gt;&amp;gt;, then <code>colorBlendOp</code> <strong class=\"purple\">must</strong> equal <code>alphaBlendOp</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-advancedBlendIndependentBlend-01407",\r
+ "text": " If <a href=\"#VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT\">VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT</a>::<code>advancedBlendIndependentBlend</code> is <code>VK_FALSE</code> and <code>colorBlendOp</code> is an &amp;lt;&amp;lt;framebuffer-blend-advanced,advanced blend operation&amp;gt;&amp;gt;, then <code>colorBlendOp</code> <strong class=\"purple\">must</strong> be the same for all attachments."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-advancedBlendIndependentBlend-01408",\r
+ "text": " If <a href=\"#VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT\">VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT</a>::<code>advancedBlendIndependentBlend</code> is <code>VK_FALSE</code> and <code>alphaBlendOp</code> is an &amp;lt;&amp;lt;framebuffer-blend-advanced,advanced blend operation&amp;gt;&amp;gt;, then <code>alphaBlendOp</code> <strong class=\"purple\">must</strong> be the same for all attachments."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-advancedBlendAllOperations-01409",\r
+ "text": " If <a href=\"#VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT\">VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT</a>::<code>advancedBlendAllOperations</code> is <code>VK_FALSE</code>, then <code>colorBlendOp</code> <strong class=\"purple\">must</strong> not be <code>VK_BLEND_OP_ZERO_EXT</code>, <code>VK_BLEND_OP_SRC_EXT</code>, <code>VK_BLEND_OP_DST_EXT</code>, <code>VK_BLEND_OP_SRC_OVER_EXT</code>, <code>VK_BLEND_OP_DST_OVER_EXT</code>, <code>VK_BLEND_OP_SRC_IN_EXT</code>, <code>VK_BLEND_OP_DST_IN_EXT</code>, <code>VK_BLEND_OP_SRC_OUT_EXT</code>, <code>VK_BLEND_OP_DST_OUT_EXT</code>, <code>VK_BLEND_OP_SRC_ATOP_EXT</code>, <code>VK_BLEND_OP_DST_ATOP_EXT</code>, <code>VK_BLEND_OP_XOR_EXT</code>, <code>VK_BLEND_OP_INVERT_EXT</code>, <code>VK_BLEND_OP_INVERT_RGB_EXT</code>, <code>VK_BLEND_OP_LINEARDODGE_EXT</code>, <code>VK_BLEND_OP_LINEARBURN_EXT</code>, <code>VK_BLEND_OP_VIVIDLIGHT_EXT</code>, <code>VK_BLEND_OP_LINEARLIGHT_EXT</code>, <code>VK_BLEND_OP_PINLIGHT_EXT</code>, <code>VK_BLEND_OP_HARDMIX_EXT</code>, <code>VK_BLEND_OP_PLUS_EXT</code>, <code>VK_BLEND_OP_PLUS_CLAMPED_EXT</code>, <code>VK_BLEND_OP_PLUS_CLAMPED_ALPHA_EXT</code>, <code>VK_BLEND_OP_PLUS_DARKER_EXT</code>, <code>VK_BLEND_OP_MINUS_EXT</code>, <code>VK_BLEND_OP_MINUS_CLAMPED_EXT</code>, <code>VK_BLEND_OP_CONTRAST_EXT</code>, <code>VK_BLEND_OP_INVERT_OVG_EXT</code>, <code>VK_BLEND_OP_RED_EXT</code>, <code>VK_BLEND_OP_GREEN_EXT</code>, or <code>VK_BLEND_OP_BLUE_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAttachmentState-colorBlendOp-01410",\r
+ "text": " If <code>colorBlendOp</code> or <code>alphaBlendOp</code> is an &amp;lt;&amp;lt;framebuffer-blend-advanced,advanced blend operation&amp;gt;&amp;gt;, then <a href=\"#VkSubpassDescription\">VkSubpassDescription</a>::<code>colorAttachmentCount</code> of the subpass this pipeline is compiled against <strong class=\"purple\">must</strong> be less than or equal to <a href=\"#VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT\">VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT</a>::advancedBlendMaxColorAttachments"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdSetBlendConstants": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdSetBlendConstants-None-00612",\r
+ "text": " The bound graphics pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_DYNAMIC_STATE_BLEND_CONSTANTS</code> dynamic state enabled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetBlendConstants-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetBlendConstants-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdSetBlendConstants-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics operations"\r
+ }\r
+ ]\r
+ },\r
+ "VkPipelineColorBlendAdvancedStateCreateInfoEXT": {\r
+ "(VK_EXT_blend_operation_advanced)": [\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAdvancedStateCreateInfoEXT-srcPremultiplied-01424",\r
+ "text": " If the &amp;lt;&amp;lt;features-limits-advancedBlendNonPremultipliedSrcColor,non-premultiplied source color&amp;gt;&amp;gt; property is not supported, <code>srcPremultiplied</code> <strong class=\"purple\">must</strong> be <code>VK_TRUE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAdvancedStateCreateInfoEXT-dstPremultiplied-01425",\r
+ "text": " If the &amp;lt;&amp;lt;features-limits-advancedBlendNonPremultipliedDstColor,non-premultiplied destination color&amp;gt;&amp;gt; property is not supported, <code>dstPremultiplied</code> <strong class=\"purple\">must</strong> be <code>VK_TRUE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAdvancedStateCreateInfoEXT-blendOverlap-01426",\r
+ "text": " If the &amp;lt;&amp;lt;features-limits-advancedBlendCorrelatedOverlap,correlated overlap&amp;gt;&amp;gt; property is not supported, <code>blendOverlap</code> <strong class=\"purple\">must</strong> be <code>VK_BLEND_OVERLAP_UNCORRELATED_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAdvancedStateCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPipelineColorBlendAdvancedStateCreateInfoEXT-blendOverlap-parameter",\r
+ "text": " <code>blendOverlap</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkBlendOverlapEXT\">VkBlendOverlapEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDispatch": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-groupCountX-00386",\r
+ "text": " <code>groupCountX</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[0]"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-groupCountY-00387",\r
+ "text": " <code>groupCountY</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[1]"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-groupCountZ-00388",\r
+ "text": " <code>groupCountZ</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[2]"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00389",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00390",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00391",\r
+ "text": " A valid compute pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00392",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants with the one used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00393",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00394",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00395",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00396",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00397",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-linearTilingFeatures-00398",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-linearTilingFeatures-00399",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-None-00400",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> not have a <a href=\"#VkImageViewType\">VkImageViewType</a> of <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-commandBuffer-01844",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-commandBuffer-01845",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_POINT_COMPUTE</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatch-commandBuffer-01846",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the compute pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_POINT_COMPUTE</code> reads from any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDispatchIndirect": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-buffer-00401",\r
+ "text": " If <code>buffer</code> is non-sparse then it <strong class=\"purple\">must</strong> be bound completely and contiguously to a single <code>VkDeviceMemory</code> object"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00402",\r
+ "text": " For each set <em>n</em> that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, a descriptor set <strong class=\"purple\">must</strong> have been bound to <em>n</em> at <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, with a <code>VkPipelineLayout</code> that is compatible for set <em>n</em>, with the <code>VkPipelineLayout</code> used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00403",\r
+ "text": " Descriptors in each bound descriptor set, specified via <code>vkCmdBindDescriptorSets</code>, <strong class=\"purple\">must</strong> be valid if they are statically used by the bound <code>VkPipeline</code> object, specified via <code>vkCmdBindPipeline</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00404",\r
+ "text": " A valid compute pipeline <strong class=\"purple\">must</strong> be bound to the current command buffer with <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-buffer-00405",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> have been created with the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-offset-00406",\r
+ "text": " <code>offset</code> <strong class=\"purple\">must</strong> be a multiple of <code>4</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-offset-00407",\r
+ "text": " The sum of <code>offset</code> and the size of <code>VkDispatchIndirectCommand</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>buffer</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00408",\r
+ "text": " For each push constant that is statically used by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, a push constant value <strong class=\"purple\">must</strong> have been set for <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>, with a <code>VkPipelineLayout</code> that is compatible for push constants with the one used to create the current <code>VkPipeline</code>, as described in &amp;lt;&amp;lt;descriptorsets-compatibility&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00409",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used to sample from any <code>VkImage</code> with a <code>VkImageView</code> of the type <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, <code>VK_IMAGE_VIEW_TYPE_1D_ARRAY</code>, <code>VK_IMAGE_VIEW_TYPE_2D_ARRAY</code> or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00410",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions with <code>ImplicitLod</code>, <code>Dref</code> or <code>Proj</code> in their name, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00411",\r
+ "text": " If any <code>VkSampler</code> object that is accessed from a shader by the <code>VkPipeline</code> bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> uses unnormalized coordinates, it <strong class=\"purple\">must</strong> not be used with any of the SPIR-V <code>OpImageSample*</code> or <code>OpImageSparseSample*</code> instructions that includes a LOD bias or any offset values, in any shader stage"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00412",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> accesses a uniform buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00413",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-robustBufferAccess,robust buffer access&amp;gt;&amp;gt; feature is not enabled, and any shader stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> accesses a storage buffer, it <strong class=\"purple\">must</strong> not access values outside of the range of that buffer specified in the bound descriptor set"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-linearTilingFeatures-00414",\r
+ "text": " Any <code>VkImageView</code> being sampled with <code>VK_FILTER_LINEAR</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports linear filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commonparent",\r
+ "text": " Both of <code>buffer</code>, and <code>commandBuffer</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_IMG_filter_cubic)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-linearTilingFeatures-00415",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> be of a format which supports cubic filtering, as specified by the <code>VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG</code> flag in <code>VkFormatProperties</code>::<code>linearTilingFeatures</code> (for a linear image) or <code>VkFormatProperties</code>::<code>optimalTilingFeatures</code>(for an optimally tiled image) returned by <code>vkGetPhysicalDeviceFormatProperties</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-None-00416",\r
+ "text": " Any <a href=\"#VkImageView\">VkImageView</a> being sampled with <code>VK_FILTER_CUBIC_IMG</code> as a result of this command <strong class=\"purple\">must</strong> not have a <a href=\"#VkImageViewType\">VkImageViewType</a> of <code>VK_IMAGE_VIEW_TYPE_3D</code>, <code>VK_IMAGE_VIEW_TYPE_CUBE</code>, or <code>VK_IMAGE_VIEW_TYPE_CUBE_ARRAY</code>"\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commandBuffer-01847",\r
+ "text": " If <code>commandBuffer</code> is an unprotected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_BIND_POINT_COMPUTE</code> reads from or writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commandBuffer-01848",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_POINT_COMPUTE</code> writes to any image or buffer, that image or buffer <strong class=\"purple\">must</strong> not be an unprotected image or unprotected buffer."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchIndirect-commandBuffer-01849",\r
+ "text": " If <code>commandBuffer</code> is a protected command buffer, and any pipeline stage other than the compute pipeline stage in the <code>VkPipeline</code> object bound to <code>VK_PIPELINE_POINT_COMPUTE</code> reads from any image or buffer, the image or buffer <strong class=\"purple\">must</strong> not be a protected image or protected buffer."\r
+ }\r
+ ]\r
+ },\r
+ "VkDispatchIndirectCommand": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkDispatchIndirectCommand-x-00417",\r
+ "text": " <code>x</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[0]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDispatchIndirectCommand-y-00418",\r
+ "text": " <code>y</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[1]"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDispatchIndirectCommand-z-00419",\r
+ "text": " <code>z</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[2]"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDispatchBase": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-None-00420",\r
+ "text": " All valid usage rules from <a href=\"#vkCmdDispatch\">vkCmdDispatch</a> apply"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-baseGroupX-00421",\r
+ "text": " <code>baseGroupX</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[0]"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-baseGroupX-00422",\r
+ "text": " <code>baseGroupX</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[1]"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-baseGroupZ-00423",\r
+ "text": " <code>baseGroupZ</code> <strong class=\"purple\">must</strong> be less than <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[2]"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-groupCountX-00424",\r
+ "text": " <code>groupCountX</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[0] minus <code>baseGroupX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-groupCountY-00425",\r
+ "text": " <code>groupCountY</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[1] minus <code>baseGroupY</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-groupCountZ-00426",\r
+ "text": " <code>groupCountZ</code> <strong class=\"purple\">must</strong> be less than or equal to <code>VkPhysicalDeviceLimits</code>::<code>maxComputeWorkGroupCount</code>[2] minus <code>baseGroupZ</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-baseGroupX-00427",\r
+ "text": " If any of <code>baseGroupX</code>, <code>baseGroupY</code>, or <code>baseGroupZ</code> are not zero, then the bound compute pipeline <strong class=\"purple\">must</strong> have been created with the <code>VK_PIPELINE_CREATE_DISPATCH_BASE</code> flag."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDispatchBase-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called outside of a render pass instance"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX-pFeatures-parameter",\r
+ "text": " <code>pFeatures</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDeviceGeneratedCommandsFeaturesNVX</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX-pLimits-parameter",\r
+ "text": " <code>pLimits</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDeviceGeneratedCommandsLimitsNVX</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGeneratedCommandsFeaturesNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGeneratedCommandsFeaturesNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGeneratedCommandsFeaturesNVX-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGeneratedCommandsLimitsNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGeneratedCommandsLimitsNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGeneratedCommandsLimitsNVX-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateObjectTableNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkCreateObjectTableNVX-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateObjectTableNVX-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkObjectTableCreateInfoNVX</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateObjectTableNVX-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateObjectTableNVX-pObjectTable-parameter",\r
+ "text": " <code>pObjectTable</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkObjectTableNVX</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTableCreateInfoNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-computeBindingPointSupport-01355",\r
+ "text": " If the <code>VkDeviceGeneratedCommandsFeaturesNVX</code>::<code>computeBindingPointSupport</code> feature is not enabled, <code>pObjectEntryUsageFlags</code> <strong class=\"purple\">must</strong> not contain <code>VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-pObjectEntryCounts-01356",\r
+ "text": " Any value within <code>pObjectEntryCounts</code> <strong class=\"purple\">must</strong> not exceed <code>VkDeviceGeneratedCommandsLimitsNVX</code>::<code>maxObjectEntryCounts</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-maxUniformBuffersPerDescriptor-01357",\r
+ "text": " <code>maxUniformBuffersPerDescriptor</code> <strong class=\"purple\">must</strong> be within the limits supported by the device."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-maxStorageBuffersPerDescriptor-01358",\r
+ "text": " <code>maxStorageBuffersPerDescriptor</code> <strong class=\"purple\">must</strong> be within the limits supported by the device."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-maxStorageImagesPerDescriptor-01359",\r
+ "text": " <code>maxStorageImagesPerDescriptor</code> <strong class=\"purple\">must</strong> be within the limits supported by the device."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-maxSampledImagesPerDescriptor-01360",\r
+ "text": " <code>maxSampledImagesPerDescriptor</code> <strong class=\"purple\">must</strong> be within the limits supported by the device."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-pObjectEntryTypes-parameter",\r
+ "text": " <code>pObjectEntryTypes</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-pObjectEntryCounts-parameter",\r
+ "text": " <code>pObjectEntryCounts</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-pObjectEntryUsageFlags-parameter",\r
+ "text": " <code>pObjectEntryUsageFlags</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> valid combinations of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-pObjectEntryUsageFlags-requiredbitmask",\r
+ "text": " Each element of <code>pObjectEntryUsageFlags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableCreateInfoNVX-objectCount-arraylength",\r
+ "text": " <code>objectCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyObjectTableNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-objectTable-01361",\r
+ "text": " All submitted commands that refer to <code>objectTable</code> <strong class=\"purple\">must</strong> have completed execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-objectTable-01362",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>objectTable</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-objectTable-01363",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>objectTable</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-objectTable-parameter",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> be a valid <code>VkObjectTableNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyObjectTableNVX-objectTable-parent",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkRegisterObjectsNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-pObjectTableEntry-01364",\r
+ "text": " The contents of <code>pObjectTableEntry</code> <strong class=\"purple\">must</strong> yield plausible bindings supported by the device."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-pObjectIndices-01365",\r
+ "text": " At any <code>pObjectIndices</code> there <strong class=\"purple\">must</strong> not be a registered resource already."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-pObjectIndices-01366",\r
+ "text": " Any value inside <code>pObjectIndices</code> <strong class=\"purple\">must</strong> be below the appropriate <code>VkObjectTableCreateInfoNVX</code>::<code>pObjectEntryCounts</code> limits provided at <code>objectTable</code> creation time."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-objectTable-parameter",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> be a valid <code>VkObjectTableNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-ppObjectTableEntries-parameter",\r
+ "text": " <code>ppObjectTableEntries</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> valid <code>VkObjectTableEntryNVX</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-pObjectIndices-parameter",\r
+ "text": " <code>pObjectIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-objectCount-arraylength",\r
+ "text": " <code>objectCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkRegisterObjectsNVX-objectTable-parent",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTableEntryNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTableEntryNVX-computeBindingPointSupport-01367",\r
+ "text": " If the <code>VkDeviceGeneratedCommandsFeaturesNVX</code>::<code>computeBindingPointSupport</code> feature is not enabled, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableEntryNVX-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableEntryNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableEntryNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTablePipelineEntryNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTablePipelineEntryNVX-type-01368",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be <code>VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePipelineEntryNVX-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePipelineEntryNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePipelineEntryNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePipelineEntryNVX-pipeline-parameter",\r
+ "text": " <code>pipeline</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipeline</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTableDescriptorSetEntryNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-type-01369",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be <code>VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-pipelineLayout-parameter",\r
+ "text": " <code>pipelineLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-descriptorSet-parameter",\r
+ "text": " <code>descriptorSet</code> <strong class=\"purple\">must</strong> be a valid <code>VkDescriptorSet</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableDescriptorSetEntryNVX-commonparent",\r
+ "text": " Both of <code>descriptorSet</code>, and <code>pipelineLayout</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTableVertexBufferEntryNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTableVertexBufferEntryNVX-type-01370",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be <code>VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableVertexBufferEntryNVX-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableVertexBufferEntryNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableVertexBufferEntryNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableVertexBufferEntryNVX-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTableIndexBufferEntryNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTableIndexBufferEntryNVX-type-01371",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be <code>VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableIndexBufferEntryNVX-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableIndexBufferEntryNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableIndexBufferEntryNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableIndexBufferEntryNVX-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTableIndexBufferEntryNVX-indexType-parameter",\r
+ "text": " <code>indexType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkIndexType\">VkIndexType</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkObjectTablePushConstantEntryNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-type-01372",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be <code>VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkObjectEntryUsageFlagBitsNVX\">VkObjectEntryUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-pipelineLayout-parameter",\r
+ "text": " <code>pipelineLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkPipelineLayout</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-stageFlags-parameter",\r
+ "text": " <code>stageFlags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkShaderStageFlagBits\">VkShaderStageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkObjectTablePushConstantEntryNVX-stageFlags-requiredbitmask",\r
+ "text": " <code>stageFlags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkUnregisterObjectsNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-pObjectIndices-01373",\r
+ "text": " At any <code>pObjectIndices</code> there <strong class=\"purple\">must</strong> be a registered resource already."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-pObjectEntryTypes-01374",\r
+ "text": " The <code>pObjectEntryTypes</code> of the resource at <code>pObjectIndices</code> <strong class=\"purple\">must</strong> match."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-None-01375",\r
+ "text": " All operations on the device using the registered resource <strong class=\"purple\">must</strong> have been completed."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-objectTable-parameter",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> be a valid <code>VkObjectTableNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-pObjectEntryTypes-parameter",\r
+ "text": " <code>pObjectEntryTypes</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> valid <a href=\"#VkObjectEntryTypeNVX\">VkObjectEntryTypeNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-pObjectIndices-parameter",\r
+ "text": " <code>pObjectIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>objectCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-objectCount-arraylength",\r
+ "text": " <code>objectCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkUnregisterObjectsNVX-objectTable-parent",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkIndirectCommandsLayoutTokenNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutTokenNVX-bindingUnit-01342",\r
+ "text": " <code>bindingUnit</code> <strong class=\"purple\">must</strong> stay within device supported limits for the appropriate commands."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutTokenNVX-dynamicCount-01343",\r
+ "text": " <code>dynamicCount</code> <strong class=\"purple\">must</strong> stay within device supported limits for the appropriate commands."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutTokenNVX-divisor-01344",\r
+ "text": " <code>divisor</code> <strong class=\"purple\">must</strong> be greater than <code>0</code> and a power of two."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutTokenNVX-tokenType-parameter",\r
+ "text": " <code>tokenType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkIndirectCommandsTokenTypeNVX\">VkIndirectCommandsTokenTypeNVX</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkIndirectCommandsTokenNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsTokenNVX-buffer-01345",\r
+ "text": " The <code>buffer</code>’s usage flag <strong class=\"purple\">must</strong> have the <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsTokenNVX-offset-01346",\r
+ "text": " The <code>offset</code> <strong class=\"purple\">must</strong> be aligned to <code>VkDeviceGeneratedCommandsLimitsNVX</code>::<code>minCommandsTokenBufferOffsetAlignment</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsTokenNVX-tokenType-parameter",\r
+ "text": " <code>tokenType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkIndirectCommandsTokenTypeNVX\">VkIndirectCommandsTokenTypeNVX</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsTokenNVX-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateIndirectCommandsLayoutNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkCreateIndirectCommandsLayoutNVX-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateIndirectCommandsLayoutNVX-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkIndirectCommandsLayoutCreateInfoNVX</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateIndirectCommandsLayoutNVX-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateIndirectCommandsLayoutNVX-pIndirectCommandsLayout-parameter",\r
+ "text": " <code>pIndirectCommandsLayout</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkIndirectCommandsLayoutNVX</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkIndirectCommandsLayoutCreateInfoNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-tokenCount-01347",\r
+ "text": " <code>tokenCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code> and below <code>VkDeviceGeneratedCommandsLimitsNVX</code>::<code>maxIndirectCommandsLayoutTokenCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-computeBindingPointSupport-01348",\r
+ "text": " If the <code>VkDeviceGeneratedCommandsFeaturesNVX</code>::<code>computeBindingPointSupport</code> feature is not enabled, then <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> not be <code>VK_PIPELINE_BIND_POINT_COMPUTE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-pTokens-01349",\r
+ "text": " If <code>pTokens</code> contains an entry of <code>VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX</code> it <strong class=\"purple\">must</strong> be the first element of the array and there <strong class=\"purple\">must</strong> be only a single element of such token type."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-pTokens-01350",\r
+ "text": " All state binding tokens in <code>pTokens</code> <strong class=\"purple\">must</strong> occur prior work provoking tokens (<code>VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX</code>, <code>VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED_NVX</code>, <code>VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX</code>)."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-pTokens-01351",\r
+ "text": " The content of <code>pTokens</code> <strong class=\"purple\">must</strong> include one single work provoking token that is compatible with the <code>pipelineBindPoint</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-pipelineBindPoint-parameter",\r
+ "text": " <code>pipelineBindPoint</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPipelineBindPoint\">VkPipelineBindPoint</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkIndirectCommandsLayoutUsageFlagBitsNVX\">VkIndirectCommandsLayoutUsageFlagBitsNVX</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-pTokens-parameter",\r
+ "text": " <code>pTokens</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>tokenCount</code> valid <code>VkIndirectCommandsLayoutTokenNVX</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIndirectCommandsLayoutCreateInfoNVX-tokenCount-arraylength",\r
+ "text": " <code>tokenCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyIndirectCommandsLayoutNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-indirectCommandsLayout-01352",\r
+ "text": " All submitted commands that refer to <code>indirectCommandsLayout</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-objectTable-01353",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>objectTable</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-objectTable-01354",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>objectTable</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-indirectCommandsLayout-parameter",\r
+ "text": " <code>indirectCommandsLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkIndirectCommandsLayoutNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyIndirectCommandsLayoutNVX-indirectCommandsLayout-parent",\r
+ "text": " <code>indirectCommandsLayout</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdReserveSpaceForCommandsNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-commandBuffer-01329",\r
+ "text": " The provided <code>commandBuffer</code> <strong class=\"purple\">must</strong> not have had a prior space reservation since its creation or the last reset."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-commandBuffer-01330",\r
+ "text": " The state of the <code>commandBuffer</code> <strong class=\"purple\">must</strong> be legal to execute all commands within the sequence provided by the <code>indirectCommandsLayout</code> member of <code>pProcessCommandsInfo</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-pReserveSpaceInfo-parameter",\r
+ "text": " <code>pReserveSpaceInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkCmdReserveSpaceForCommandsInfoNVX</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdReserveSpaceForCommandsNVX-bufferlevel",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a secondary <code>VkCommandBuffer</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkCmdReserveSpaceForCommandsInfoNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkCmdReserveSpaceForCommandsInfoNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdReserveSpaceForCommandsInfoNVX-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdReserveSpaceForCommandsInfoNVX-objectTable-parameter",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> be a valid <code>VkObjectTableNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdReserveSpaceForCommandsInfoNVX-indirectCommandsLayout-parameter",\r
+ "text": " <code>indirectCommandsLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkIndirectCommandsLayoutNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdReserveSpaceForCommandsInfoNVX-commonparent",\r
+ "text": " Both of <code>indirectCommandsLayout</code>, and <code>objectTable</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdProcessCommandsNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-vkCmdProcessCommandsNVX-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdProcessCommandsNVX-pProcessCommandsInfo-parameter",\r
+ "text": " <code>pProcessCommandsInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkCmdProcessCommandsInfoNVX</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdProcessCommandsNVX-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdProcessCommandsNVX-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdProcessCommandsNVX-renderpass",\r
+ "text": " This command <strong class=\"purple\">must</strong> only be called inside of a render pass instance"\r
+ }\r
+ ]\r
+ },\r
+ "VkCmdProcessCommandsInfoNVX": {\r
+ "(VK_NVX_device_generated_commands)": [\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-objectTable-01331",\r
+ "text": " The provided <code>objectTable</code> <strong class=\"purple\">must</strong> include all objects referenced by the generation process."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-indirectCommandsTokenCount-01332",\r
+ "text": " <code>indirectCommandsTokenCount</code> <strong class=\"purple\">must</strong> match the <code>indirectCommandsLayout</code>’s <code>tokenCount</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-tokenType-01333",\r
+ "text": " The <code>tokenType</code> member of each entry in the <code>pIndirectCommandsTokens</code> array <strong class=\"purple\">must</strong> match the values used at creation time of <code>indirectCommandsLayout</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-targetCommandBuffer-01334",\r
+ "text": " If <code>targetCommandBuffer</code> is provided, it <strong class=\"purple\">must</strong> have reserved command space."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-targetCommandBuffer-01335",\r
+ "text": " If <code>targetCommandBuffer</code> is provided, the <code>objectTable</code> <strong class=\"purple\">must</strong> match the reservation’s objectTable and <strong class=\"purple\">must</strong> have had all referenced objects registered at reservation time."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-targetCommandBuffer-01336",\r
+ "text": " If <code>targetCommandBuffer</code> is provided, the <code>indirectCommandsLayout</code> <strong class=\"purple\">must</strong> match the reservation’s indirectCommandsLayout."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-targetCommandBuffer-01337",\r
+ "text": " If <code>targetCommandBuffer</code> is provided, the <code>maxSequencesCount</code> <strong class=\"purple\">must</strong> not exceed the reservation’s maxSequencesCount."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sequencesCountBuffer-01338",\r
+ "text": " If <code>sequencesCountBuffer</code> is used, its usage flag <strong class=\"purple\">must</strong> have <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sequencesCountBuffer-01339",\r
+ "text": " If <code>sequencesCountBuffer</code> is used, <code>sequencesCountOffset</code> <strong class=\"purple\">must</strong> be aligned to <code>VkDeviceGeneratedCommandsLimitsNVX</code>::<code>minSequenceCountBufferOffsetAlignment</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sequencesIndexBuffer-01340",\r
+ "text": " If <code>sequencesIndexBuffer</code> is used, its usage flag <strong class=\"purple\">must</strong> have <code>VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT</code> bit set."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sequencesIndexBuffer-01341",\r
+ "text": " If <code>sequencesIndexBuffer</code> is used, <code>sequencesIndexOffset</code> <strong class=\"purple\">must</strong> be aligned to <code>VkDeviceGeneratedCommandsLimitsNVX</code>::<code>minSequenceIndexBufferOffsetAlignment</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-objectTable-parameter",\r
+ "text": " <code>objectTable</code> <strong class=\"purple\">must</strong> be a valid <code>VkObjectTableNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-indirectCommandsLayout-parameter",\r
+ "text": " <code>indirectCommandsLayout</code> <strong class=\"purple\">must</strong> be a valid <code>VkIndirectCommandsLayoutNVX</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-pIndirectCommandsTokens-parameter",\r
+ "text": " <code>pIndirectCommandsTokens</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>indirectCommandsTokenCount</code> valid <code>VkIndirectCommandsTokenNVX</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-targetCommandBuffer-parameter",\r
+ "text": " If <code>targetCommandBuffer</code> is not <code>NULL</code>, <code>targetCommandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sequencesCountBuffer-parameter",\r
+ "text": " If <code>sequencesCountBuffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>sequencesCountBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-sequencesIndexBuffer-parameter",\r
+ "text": " If <code>sequencesIndexBuffer</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>sequencesIndexBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-indirectCommandsTokenCount-arraylength",\r
+ "text": " <code>indirectCommandsTokenCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkCmdProcessCommandsInfoNVX-commonparent",\r
+ "text": " Each of <code>indirectCommandsLayout</code>, <code>objectTable</code>, <code>sequencesCountBuffer</code>, <code>sequencesIndexBuffer</code>, and <code>targetCommandBuffer</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSparseImageFormatProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-samples-01094",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a bit value that is set in <code>VkImageFormatProperties</code>::<code>sampleCounts</code> returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>type</code>, <code>tiling</code>, and <code>usage</code> equal to those in this command and <code>flags</code> equal to the value that is set in <code>VkImageCreateInfo</code>::<code>flags</code> when the image is created"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageType\">VkImageType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-samples-parameter",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-tiling-parameter",\r
+ "text": " <code>tiling</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageTiling\">VkImageTiling</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkSparseImageFormatProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSparseImageFormatProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties2-pFormatInfo-parameter",\r
+ "text": " <code>pFormatInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceSparseImageFormatInfo2</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties2-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSparseImageFormatProperties2-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkSparseImageFormatProperties2</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceSparseImageFormatInfo2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-samples-01095",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a bit value that is set in <code>VkImageFormatProperties</code>::<code>sampleCounts</code> returned by <code>vkGetPhysicalDeviceImageFormatProperties</code> with <code>format</code>, <code>type</code>, <code>tiling</code>, and <code>usage</code> equal to those in this command and <code>flags</code> equal to the value that is set in <code>VkImageCreateInfo</code>::<code>flags</code> when the image is created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageType\">VkImageType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-samples-parameter",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSparseImageFormatInfo2-tiling-parameter",\r
+ "text": " <code>tiling</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageTiling\">VkImageTiling</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseImageFormatProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkSparseImageFormatProperties2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageFormatProperties2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetImageSparseMemoryRequirements": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements-pSparseMemoryRequirementCount-parameter",\r
+ "text": " <code>pSparseMemoryRequirementCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements-pSparseMemoryRequirements-parameter",\r
+ "text": " If the value referenced by <code>pSparseMemoryRequirementCount</code> is not <code>0</code>, and <code>pSparseMemoryRequirements</code> is not <code>NULL</code>, <code>pSparseMemoryRequirements</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pSparseMemoryRequirementCount</code> <code>VkSparseImageMemoryRequirements</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements-image-parent",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetImageSparseMemoryRequirements2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements2-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements2-pInfo-parameter",\r
+ "text": " <code>pInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkImageSparseMemoryRequirementsInfo2</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements2-pSparseMemoryRequirementCount-parameter",\r
+ "text": " <code>pSparseMemoryRequirementCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetImageSparseMemoryRequirements2-pSparseMemoryRequirements-parameter",\r
+ "text": " If the value referenced by <code>pSparseMemoryRequirementCount</code> is not <code>0</code>, and <code>pSparseMemoryRequirements</code> is not <code>NULL</code>, <code>pSparseMemoryRequirements</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pSparseMemoryRequirementCount</code> <code>VkSparseImageMemoryRequirements2</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageSparseMemoryRequirementsInfo2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-VkImageSparseMemoryRequirementsInfo2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSparseMemoryRequirementsInfo2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageSparseMemoryRequirementsInfo2-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseImageMemoryRequirements2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_memory_requirements2)": [\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryRequirements2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryRequirements2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseMemoryBind": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-memory-01096",\r
+ "text": " If <code>memory</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>memory</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> match the memory requirements of the resource, as described in section &amp;lt;&amp;lt;resources-association&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-memory-01097",\r
+ "text": " If <code>memory</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>memory</code> <strong class=\"purple\">must</strong> not have been created with a memory type that reports <code>VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT</code> bit set"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-size-01098",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-resourceOffset-01099",\r
+ "text": " <code>resourceOffset</code> <strong class=\"purple\">must</strong> be less than the size of the resource"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-size-01100",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to the size of the resource minus <code>resourceOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-memoryOffset-01101",\r
+ "text": " <code>memoryOffset</code> <strong class=\"purple\">must</strong> be less than the size of <code>memory</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-size-01102",\r
+ "text": " <code>size</code> <strong class=\"purple\">must</strong> be less than or equal to the size of <code>memory</code> minus <code>memoryOffset</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-memory-parameter",\r
+ "text": " If <code>memory</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseMemoryBind-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSparseMemoryBindFlagBits\">VkSparseMemoryBindFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseBufferMemoryBindInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSparseBufferMemoryBindInfo-buffer-parameter",\r
+ "text": " <code>buffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseBufferMemoryBindInfo-pBinds-parameter",\r
+ "text": " <code>pBinds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindCount</code> valid <code>VkSparseMemoryBind</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseBufferMemoryBindInfo-bindCount-arraylength",\r
+ "text": " <code>bindCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseImageOpaqueMemoryBindInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSparseImageOpaqueMemoryBindInfo-pBinds-01103",\r
+ "text": " If the <code>flags</code> member of any element of <code>pBinds</code> contains <code>VK_SPARSE_MEMORY_BIND_METADATA_BIT</code>, the binding range defined <strong class=\"purple\">must</strong> be within the mip tail region of the metadata aspect of <code>image</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageOpaqueMemoryBindInfo-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageOpaqueMemoryBindInfo-pBinds-parameter",\r
+ "text": " <code>pBinds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindCount</code> valid <code>VkSparseMemoryBind</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageOpaqueMemoryBindInfo-bindCount-arraylength",\r
+ "text": " <code>bindCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseImageMemoryBindInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBindInfo-subresource-01722",\r
+ "text": " The <code>subresource.mipLevel</code> member of each element of <code>pBinds</code> <strong class=\"purple\">must</strong> be less than the <code>mipLevels</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBindInfo-subresource-01723",\r
+ "text": " The <code>subresource.arrayLayer</code> member of each element of <code>pBinds</code> <strong class=\"purple\">must</strong> be less than the <code>arrayLayers</code> specified in <a href=\"#VkImageCreateInfo\">VkImageCreateInfo</a> when <code>image</code> was created"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBindInfo-image-parameter",\r
+ "text": " <code>image</code> <strong class=\"purple\">must</strong> be a valid <code>VkImage</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBindInfo-pBinds-parameter",\r
+ "text": " <code>pBinds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindCount</code> valid <code>VkSparseImageMemoryBind</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBindInfo-bindCount-arraylength",\r
+ "text": " <code>bindCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSparseImageMemoryBind": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-memory-01104",\r
+ "text": " If the &amp;lt;&amp;lt;features-features-sparseResidencyAliased,sparse aliased residency&amp;gt;&amp;gt; feature is not enabled, and if any other resources are bound to ranges of <code>memory</code>, the range of <code>memory</code> being bound <strong class=\"purple\">must</strong> not overlap with those bound ranges"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-memory-01105",\r
+ "text": " <code>memory</code> and <code>memoryOffset</code> <strong class=\"purple\">must</strong> match the memory requirements of the calling command’s <code>image</code>, as described in section &amp;lt;&amp;lt;resources-association&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-subresource-01106",\r
+ "text": " <code>subresource</code> <strong class=\"purple\">must</strong> be a valid image subresource for <code>image</code> (see &amp;lt;&amp;lt;resources-image-views&amp;gt;&amp;gt;)"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-offset-01107",\r
+ "text": " <code>offset.x</code> <strong class=\"purple\">must</strong> be a multiple of the sparse image block width (<code>VkSparseImageFormatProperties</code>::<code>imageGranularity.width</code>) of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-extent-01108",\r
+ "text": " <code>extent.width</code> <strong class=\"purple\">must</strong> either be a multiple of the sparse image block width of the image, or else <span class=\"eq\">(<code>extent.width</code> + <code>offset.x</code>)</span> <strong class=\"purple\">must</strong> equal the width of the image subresource"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-offset-01109",\r
+ "text": " <code>offset.y</code> <strong class=\"purple\">must</strong> be a multiple of the sparse image block height (<code>VkSparseImageFormatProperties</code>::<code>imageGranularity.height</code>) of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-extent-01110",\r
+ "text": " <code>extent.height</code> <strong class=\"purple\">must</strong> either be a multiple of the sparse image block height of the image, or else <span class=\"eq\">(<code>extent.height</code> + <code>offset.y</code>)</span> <strong class=\"purple\">must</strong> equal the height of the image subresource"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-offset-01111",\r
+ "text": " <code>offset.z</code> <strong class=\"purple\">must</strong> be a multiple of the sparse image block depth (<code>VkSparseImageFormatProperties</code>::<code>imageGranularity.depth</code>) of the image"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-extent-01112",\r
+ "text": " <code>extent.depth</code> <strong class=\"purple\">must</strong> either be a multiple of the sparse image block depth of the image, or else <span class=\"eq\">(<code>extent.depth</code> + <code>offset.z</code>)</span> <strong class=\"purple\">must</strong> equal the depth of the image subresource"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-subresource-parameter",\r
+ "text": " <code>subresource</code> <strong class=\"purple\">must</strong> be a valid <code>VkImageSubresource</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-memory-parameter",\r
+ "text": " If <code>memory</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>memory</code> <strong class=\"purple\">must</strong> be a valid <code>VkDeviceMemory</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSparseImageMemoryBind-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSparseMemoryBindFlagBits\">VkSparseMemoryBindFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkQueueBindSparse": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-fence-01113",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be unsignaled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-fence-01114",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> not be associated with any other queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-pSignalSemaphores-01115",\r
+ "text": " Each element of the <code>pSignalSemaphores</code> member of each element of <code>pBindInfo</code> <strong class=\"purple\">must</strong> be unsignaled when the semaphore signal operation it defines is executed on the device"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-pWaitSemaphores-01116",\r
+ "text": " When a semaphore unsignal operation defined by any element of the <code>pWaitSemaphores</code> member of any element of <code>pBindInfo</code> executes on <code>queue</code>, no other queue <strong class=\"purple\">must</strong> be waiting on the same semaphore."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-pWaitSemaphores-01117",\r
+ "text": " All elements of the <code>pWaitSemaphores</code> member of all elements of <code>pBindInfo</code> <strong class=\"purple\">must</strong> be semaphores that are signaled, or have &amp;lt;&amp;lt;synchronization-semaphores-signaling, semaphore signal operations&amp;gt;&amp;gt; previously submitted for execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-pBindInfo-parameter",\r
+ "text": " If <code>bindInfoCount</code> is not <code>0</code>, <code>pBindInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bindInfoCount</code> valid <code>VkBindSparseInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-fence-parameter",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-queuetype",\r
+ "text": " The <code>queue</code> <strong class=\"purple\">must</strong> support sparse binding operations"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBindSparse-commonparent",\r
+ "text": " Both of <code>fence</code>, and <code>queue</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkBindSparseInfo": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_BIND_SPARSE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceGroupBindSparseInfo\">VkDeviceGroupBindSparseInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-pWaitSemaphores-parameter",\r
+ "text": " If <code>waitSemaphoreCount</code> is not <code>0</code>, <code>pWaitSemaphores</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>waitSemaphoreCount</code> valid <code>VkSemaphore</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-pBufferBinds-parameter",\r
+ "text": " If <code>bufferBindCount</code> is not <code>0</code>, <code>pBufferBinds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>bufferBindCount</code> valid <code>VkSparseBufferMemoryBindInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-pImageOpaqueBinds-parameter",\r
+ "text": " If <code>imageOpaqueBindCount</code> is not <code>0</code>, <code>pImageOpaqueBinds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>imageOpaqueBindCount</code> valid <code>VkSparseImageOpaqueMemoryBindInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-pImageBinds-parameter",\r
+ "text": " If <code>imageBindCount</code> is not <code>0</code>, <code>pImageBinds</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>imageBindCount</code> valid <code>VkSparseImageMemoryBindInfo</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-pSignalSemaphores-parameter",\r
+ "text": " If <code>signalSemaphoreCount</code> is not <code>0</code>, <code>pSignalSemaphores</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>signalSemaphoreCount</code> valid <code>VkSemaphore</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkBindSparseInfo-commonparent",\r
+ "text": " Both of the elements of <code>pSignalSemaphores</code>, and the elements of <code>pWaitSemaphores</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkDevice</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupBindSparseInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupBindSparseInfo-resourceDeviceIndex-01118",\r
+ "text": " <code>resourceDeviceIndex</code> and <code>memoryDeviceIndex</code> <strong class=\"purple\">must</strong> both be valid device indices."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupBindSparseInfo-memoryDeviceIndex-01119",\r
+ "text": " Each memory allocation bound in this batch <strong class=\"purple\">must</strong> have allocated an instance for <code>memoryDeviceIndex</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupBindSparseInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateAndroidSurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_android_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateAndroidSurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateAndroidSurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAndroidSurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateAndroidSurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateAndroidSurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkAndroidSurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_android_surface)": [\r
+ {\r
+ "vuid": "VUID-VkAndroidSurfaceCreateInfoKHR-window-01248",\r
+ "text": " <code>window</code> <strong class=\"purple\">must</strong> point to a valid Android <code>ANativeWindow</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAndroidSurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAndroidSurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAndroidSurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateMirSurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_mir_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateMirSurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateMirSurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkMirSurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateMirSurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateMirSurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkMirSurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_mir_surface)": [\r
+ {\r
+ "vuid": "VUID-VkMirSurfaceCreateInfoKHR-connection-01263",\r
+ "text": " <code>connection</code> <strong class=\"purple\">must</strong> point to a valid <code>MirConnection</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMirSurfaceCreateInfoKHR-surface-01264",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> point to a valid <code>MirSurface</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMirSurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMirSurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMirSurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateWaylandSurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_wayland_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateWaylandSurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateWaylandSurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkWaylandSurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateWaylandSurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateWaylandSurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkWaylandSurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_wayland_surface)": [\r
+ {\r
+ "vuid": "VUID-VkWaylandSurfaceCreateInfoKHR-display-01304",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> point to a valid Wayland <code>wl_display</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWaylandSurfaceCreateInfoKHR-surface-01305",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> point to a valid Wayland <code>wl_surface</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWaylandSurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWaylandSurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWaylandSurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateWin32SurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_win32_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateWin32SurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateWin32SurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkWin32SurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateWin32SurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateWin32SurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkWin32SurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_win32_surface)": [\r
+ {\r
+ "vuid": "VUID-VkWin32SurfaceCreateInfoKHR-hinstance-01307",\r
+ "text": " <code>hinstance</code> <strong class=\"purple\">must</strong> be a valid Win32 <code>HINSTANCE</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32SurfaceCreateInfoKHR-hwnd-01308",\r
+ "text": " <code>hwnd</code> <strong class=\"purple\">must</strong> be a valid Win32 <code>HWND</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32SurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32SurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkWin32SurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateXcbSurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_xcb_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateXcbSurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateXcbSurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkXcbSurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateXcbSurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateXcbSurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkXcbSurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_xcb_surface)": [\r
+ {\r
+ "vuid": "VUID-VkXcbSurfaceCreateInfoKHR-connection-01310",\r
+ "text": " <code>connection</code> <strong class=\"purple\">must</strong> point to a valid X11 <code>xcb_connection_t</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXcbSurfaceCreateInfoKHR-window-01311",\r
+ "text": " <code>window</code> <strong class=\"purple\">must</strong> be a valid X11 <code>xcb_window_t</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXcbSurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXcbSurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXcbSurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateXlibSurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_xlib_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateXlibSurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateXlibSurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkXlibSurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateXlibSurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateXlibSurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkXlibSurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_xlib_surface)": [\r
+ {\r
+ "vuid": "VUID-VkXlibSurfaceCreateInfoKHR-dpy-01313",\r
+ "text": " <code>dpy</code> <strong class=\"purple\">must</strong> point to a valid Xlib <code>Display</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXlibSurfaceCreateInfoKHR-window-01314",\r
+ "text": " <code>window</code> <strong class=\"purple\">must</strong> be a valid Xlib <code>Window</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXlibSurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXlibSurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkXlibSurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateIOSSurfaceMVK": {\r
+ "(VK_KHR_surface)+(VK_MVK_ios_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateIOSSurfaceMVK-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateIOSSurfaceMVK-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkIOSSurfaceCreateInfoMVK</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateIOSSurfaceMVK-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateIOSSurfaceMVK-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkIOSSurfaceCreateInfoMVK": {\r
+ "(VK_KHR_surface)+(VK_MVK_ios_surface)": [\r
+ {\r
+ "vuid": "VUID-VkIOSSurfaceCreateInfoMVK-pView-01316",\r
+ "text": " <code>pView</code> <strong class=\"purple\">must</strong> be a valid <code>UIView</code> and <strong class=\"purple\">must</strong> be backed by a <code>CALayer</code> instance of type <code>CAMetalLayer</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIOSSurfaceCreateInfoMVK-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IOS_SURFACE_CREATE_INFO_MVK</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIOSSurfaceCreateInfoMVK-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkIOSSurfaceCreateInfoMVK-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateMacOSSurfaceMVK": {\r
+ "(VK_KHR_surface)+(VK_MVK_macos_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateMacOSSurfaceMVK-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateMacOSSurfaceMVK-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkMacOSSurfaceCreateInfoMVK</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateMacOSSurfaceMVK-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateMacOSSurfaceMVK-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkMacOSSurfaceCreateInfoMVK": {\r
+ "(VK_KHR_surface)+(VK_MVK_macos_surface)": [\r
+ {\r
+ "vuid": "VUID-VkMacOSSurfaceCreateInfoMVK-pView-01317",\r
+ "text": " <code>pView</code> <strong class=\"purple\">must</strong> be a valid <code>NSView</code> and <strong class=\"purple\">must</strong> be backed by a <code>CALayer</code> instance of type <code>CAMetalLayer</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMacOSSurfaceCreateInfoMVK-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMacOSSurfaceCreateInfoMVK-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMacOSSurfaceCreateInfoMVK-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateViSurfaceNN": {\r
+ "(VK_KHR_surface)+(VK_NN_vi_surface)": [\r
+ {\r
+ "vuid": "VUID-vkCreateViSurfaceNN-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateViSurfaceNN-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkViSurfaceCreateInfoNN</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateViSurfaceNN-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateViSurfaceNN-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkViSurfaceCreateInfoNN": {\r
+ "(VK_KHR_surface)+(VK_NN_vi_surface)": [\r
+ {\r
+ "vuid": "VUID-VkViSurfaceCreateInfoNN-window-01318",\r
+ "text": " <code>window</code> <strong class=\"purple\">must</strong> be a valid <code>nn</code>::<code>vi</code>::<code>NativeWindowHandle</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViSurfaceCreateInfoNN-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViSurfaceCreateInfoNN-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkViSurfaceCreateInfoNN-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroySurfaceKHR": {\r
+ "(VK_KHR_surface)": [\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-surface-01266",\r
+ "text": " All <code>VkSwapchainKHR</code> objects created for <code>surface</code> <strong class=\"purple\">must</strong> have been destroyed prior to destroying <code>surface</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-surface-01267",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>surface</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-surface-01268",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>surface</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-surface-parameter",\r
+ "text": " If <code>surface</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySurfaceKHR-surface-parent",\r
+ "text": " If <code>surface</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>instance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceDisplayPropertiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceDisplayPropertiesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceDisplayPropertiesKHR-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceDisplayPropertiesKHR-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkDisplayPropertiesKHR</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkAcquireXlibDisplayEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)+(VK_EXT_direct_mode_display)+(VK_EXT_acquire_xlib_display)": [\r
+ {\r
+ "vuid": "VUID-vkAcquireXlibDisplayEXT-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireXlibDisplayEXT-dpy-parameter",\r
+ "text": " <code>dpy</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>Display</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireXlibDisplayEXT-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetRandROutputDisplayEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)+(VK_EXT_direct_mode_display)+(VK_EXT_acquire_xlib_display)": [\r
+ {\r
+ "vuid": "VUID-vkGetRandROutputDisplayEXT-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRandROutputDisplayEXT-dpy-parameter",\r
+ "text": " <code>dpy</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>Display</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRandROutputDisplayEXT-pDisplay-parameter",\r
+ "text": " <code>pDisplay</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDisplayKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkReleaseDisplayEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)+(VK_EXT_direct_mode_display)": [\r
+ {\r
+ "vuid": "VUID-vkReleaseDisplayEXT-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkReleaseDisplayEXT-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceDisplayPlanePropertiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceDisplayPlanePropertiesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceDisplayPlanePropertiesKHR-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceDisplayPlanePropertiesKHR-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkDisplayPlanePropertiesKHR</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDisplayPlaneSupportedDisplaysKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneSupportedDisplaysKHR-planeIndex-01249",\r
+ "text": " <code>planeIndex</code> <strong class=\"purple\">must</strong> be less than the number of display planes supported by the device as determined by calling <code>vkGetPhysicalDeviceDisplayPlanePropertiesKHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneSupportedDisplaysKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneSupportedDisplaysKHR-pDisplayCount-parameter",\r
+ "text": " <code>pDisplayCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneSupportedDisplaysKHR-pDisplays-parameter",\r
+ "text": " If the value referenced by <code>pDisplayCount</code> is not <code>0</code>, and <code>pDisplays</code> is not <code>NULL</code>, <code>pDisplays</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pDisplayCount</code> <code>VkDisplayKHR</code> handles"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDisplayModePropertiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkGetDisplayModePropertiesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayModePropertiesKHR-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayModePropertiesKHR-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayModePropertiesKHR-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkDisplayModePropertiesKHR</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDisplayModeKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayModeKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayModeKHR-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayModeKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDisplayModeCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayModeKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayModeKHR-pMode-parameter",\r
+ "text": " <code>pMode</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDisplayModeKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDisplayModeCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-VkDisplayModeCreateInfoKHR-width-01250",\r
+ "text": " The <code>width</code> and <code>height</code> members of the <code>visibleRegion</code> member of <code>parameters</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayModeCreateInfoKHR-refreshRate-01251",\r
+ "text": " The <code>refreshRate</code> member of <code>parameters</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayModeCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayModeCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayModeCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDisplayPlaneCapabilitiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneCapabilitiesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneCapabilitiesKHR-mode-parameter",\r
+ "text": " <code>mode</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayModeKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDisplayPlaneCapabilitiesKHR-pCapabilities-parameter",\r
+ "text": " <code>pCapabilities</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDisplayPlaneCapabilitiesKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkDisplayPowerControlEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)+(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-vkDisplayPowerControlEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDisplayPowerControlEXT-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDisplayPowerControlEXT-pDisplayPowerInfo-parameter",\r
+ "text": " <code>pDisplayPowerInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDisplayPowerInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDisplayPowerInfoEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)+(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-VkDisplayPowerInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayPowerInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayPowerInfoEXT-powerState-parameter",\r
+ "text": " <code>powerState</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDisplayPowerStateEXT\">VkDisplayPowerStateEXT</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDisplayPlaneSurfaceKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayPlaneSurfaceKHR-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayPlaneSurfaceKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDisplaySurfaceCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayPlaneSurfaceKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDisplayPlaneSurfaceKHR-pSurface-parameter",\r
+ "text": " <code>pSurface</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDisplaySurfaceCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_display)": [\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-planeIndex-01252",\r
+ "text": " <code>planeIndex</code> <strong class=\"purple\">must</strong> be less than the number of display planes supported by the device as determined by calling <code>vkGetPhysicalDeviceDisplayPlanePropertiesKHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-planeReorderPossible-01253",\r
+ "text": " If the <code>planeReorderPossible</code> member of the <code>VkDisplayPropertiesKHR</code> structure returned by <code>vkGetPhysicalDeviceDisplayPropertiesKHR</code> for the display corresponding to <code>displayMode</code> is <code>VK_TRUE</code> then <code>planeStackIndex</code> <strong class=\"purple\">must</strong> be less than the number of display planes supported by the device as determined by calling <code>vkGetPhysicalDeviceDisplayPlanePropertiesKHR</code>; otherwise <code>planeStackIndex</code> <strong class=\"purple\">must</strong> equal the <code>currentStackIndex</code> member of <code>VkDisplayPlanePropertiesKHR</code> returned by <code>vkGetPhysicalDeviceDisplayPlanePropertiesKHR</code> for the display plane corresponding to <code>displayMode</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-alphaMode-01254",\r
+ "text": " If <code>alphaMode</code> is <code>VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR</code> then <code>globalAlpha</code> <strong class=\"purple\">must</strong> be between <code>0</code> and <code>1</code>, inclusive"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-alphaMode-01255",\r
+ "text": " <code>alphaMode</code> <strong class=\"purple\">must</strong> be <code>0</code> or one of the bits present in the <code>supportedAlpha</code> member of <code>VkDisplayPlaneCapabilitiesKHR</code> returned by <code>vkGetDisplayPlaneCapabilitiesKHR</code> for the display plane corresponding to <code>displayMode</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-width-01256",\r
+ "text": " The <code>width</code> and <code>height</code> members of <code>imageExtent</code> <strong class=\"purple\">must</strong> be less than the <code>maxImageDimensions2D</code> member of <code>VkPhysicalDeviceLimits</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-displayMode-parameter",\r
+ "text": " <code>displayMode</code> <strong class=\"purple\">must</strong> be a valid <code>VkDisplayModeKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-transform-parameter",\r
+ "text": " <code>transform</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSurfaceTransformFlagBitsKHR\">VkSurfaceTransformFlagBitsKHR</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplaySurfaceCreateInfoKHR-alphaMode-parameter",\r
+ "text": " <code>alphaMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDisplayPlaneAlphaFlagBitsKHR\">VkDisplayPlaneAlphaFlagBitsKHR</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfaceSupportKHR": {\r
+ "(VK_KHR_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceSupportKHR-queueFamilyIndex-01269",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> for the given <code>physicalDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceSupportKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceSupportKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceSupportKHR-pSupported-parameter",\r
+ "text": " <code>pSupported</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkBool32</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceSupportKHR-commonparent",\r
+ "text": " Both of <code>physicalDevice</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceMirPresentationSupportKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_mir_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMirPresentationSupportKHR-queueFamilyIndex-01265",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> for the given <code>physicalDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMirPresentationSupportKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMirPresentationSupportKHR-connection-parameter",\r
+ "text": " <code>connection</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>MirConnection</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceWaylandPresentationSupportKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_wayland_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceWaylandPresentationSupportKHR-queueFamilyIndex-01306",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> for the given <code>physicalDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceWaylandPresentationSupportKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceWaylandPresentationSupportKHR-display-parameter",\r
+ "text": " <code>display</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>wl_display</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceWin32PresentationSupportKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_win32_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceWin32PresentationSupportKHR-queueFamilyIndex-01309",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> for the given <code>physicalDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceWin32PresentationSupportKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceXcbPresentationSupportKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_xcb_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceXcbPresentationSupportKHR-queueFamilyIndex-01312",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> for the given <code>physicalDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceXcbPresentationSupportKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceXcbPresentationSupportKHR-connection-parameter",\r
+ "text": " <code>connection</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>xcb_connection_t</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceXlibPresentationSupportKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_xlib_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceXlibPresentationSupportKHR-queueFamilyIndex-01315",\r
+ "text": " <code>queueFamilyIndex</code> <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <code>vkGetPhysicalDeviceQueueFamilyProperties</code> for the given <code>physicalDevice</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceXlibPresentationSupportKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceXlibPresentationSupportKHR-dpy-parameter",\r
+ "text": " <code>dpy</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>Display</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfaceCapabilitiesKHR": {\r
+ "(VK_KHR_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilitiesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilitiesKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilitiesKHR-pSurfaceCapabilities-parameter",\r
+ "text": " <code>pSurfaceCapabilities</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceCapabilitiesKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilitiesKHR-commonparent",\r
+ "text": " Both of <code>physicalDevice</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfaceCapabilities2KHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_get_surface_capabilities2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2KHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2KHR-pSurfaceInfo-parameter",\r
+ "text": " <code>pSurfaceInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceSurfaceInfo2KHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2KHR-pSurfaceCapabilities-parameter",\r
+ "text": " <code>pSurfaceCapabilities</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceCapabilities2KHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceSurfaceInfo2KHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_get_surface_capabilities2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSurfaceInfo2KHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSurfaceInfo2KHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSurfaceInfo2KHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkSurfaceCapabilities2KHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_get_surface_capabilities2)": [\r
+ {\r
+ "vuid": "VUID-VkSurfaceCapabilities2KHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSurfaceCapabilities2KHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkSharedPresentSurfaceCapabilitiesKHR\">VkSharedPresentSurfaceCapabilitiesKHR</a>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSharedPresentSurfaceCapabilitiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_get_surface_capabilities2)+(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-VkSharedPresentSurfaceCapabilitiesKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfaceCapabilities2EXT": {\r
+ "(VK_KHR_surface)+(VK_EXT_display_surface_counter)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2EXT-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2EXT-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2EXT-pSurfaceCapabilities-parameter",\r
+ "text": " <code>pSurfaceCapabilities</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSurfaceCapabilities2EXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceCapabilities2EXT-commonparent",\r
+ "text": " Both of <code>physicalDevice</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSurfaceCapabilities2EXT": {\r
+ "(VK_KHR_surface)+(VK_EXT_display_surface_counter)": [\r
+ {\r
+ "vuid": "VUID-VkSurfaceCapabilities2EXT-supportedSurfaceCounters-01246",\r
+ "text": " <code>supportedSurfaceCounters</code> <strong class=\"purple\">must</strong> not include <code>VK_SURFACE_COUNTER_VBLANK_EXT</code> unless the surface queried is a &amp;lt;&amp;lt;wsi-display-surfaces,display surface&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSurfaceCapabilities2EXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSurfaceCapabilities2EXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfaceFormatsKHR": {\r
+ "(VK_KHR_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormatsKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormatsKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormatsKHR-pSurfaceFormatCount-parameter",\r
+ "text": " <code>pSurfaceFormatCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormatsKHR-pSurfaceFormats-parameter",\r
+ "text": " If the value referenced by <code>pSurfaceFormatCount</code> is not <code>0</code>, and <code>pSurfaceFormats</code> is not <code>NULL</code>, <code>pSurfaceFormats</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pSurfaceFormatCount</code> <code>VkSurfaceFormatKHR</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormatsKHR-commonparent",\r
+ "text": " Both of <code>physicalDevice</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfaceFormats2KHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_get_surface_capabilities2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormats2KHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormats2KHR-pSurfaceInfo-parameter",\r
+ "text": " <code>pSurfaceInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceSurfaceInfo2KHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormats2KHR-pSurfaceFormatCount-parameter",\r
+ "text": " <code>pSurfaceFormatCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfaceFormats2KHR-pSurfaceFormats-parameter",\r
+ "text": " If the value referenced by <code>pSurfaceFormatCount</code> is not <code>0</code>, and <code>pSurfaceFormats</code> is not <code>NULL</code>, <code>pSurfaceFormats</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pSurfaceFormatCount</code> <code>VkSurfaceFormat2KHR</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkSurfaceFormat2KHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_get_surface_capabilities2)": [\r
+ {\r
+ "vuid": "VUID-VkSurfaceFormat2KHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSurfaceFormat2KHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceSurfacePresentModesKHR": {\r
+ "(VK_KHR_surface)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfacePresentModesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfacePresentModesKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfacePresentModesKHR-pPresentModeCount-parameter",\r
+ "text": " <code>pPresentModeCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfacePresentModesKHR-pPresentModes-parameter",\r
+ "text": " If the value referenced by <code>pPresentModeCount</code> is not <code>0</code>, and <code>pPresentModes</code> is not <code>NULL</code>, <code>pPresentModes</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPresentModeCount</code> <a href=\"#VkPresentModeKHR\">VkPresentModeKHR</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceSurfacePresentModesKHR-commonparent",\r
+ "text": " Both of <code>physicalDevice</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceGroupPresentCapabilitiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPresentCapabilitiesKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupPresentCapabilitiesKHR-pDeviceGroupPresentCapabilities-parameter",\r
+ "text": " <code>pDeviceGroupPresentCapabilities</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDeviceGroupPresentCapabilitiesKHR</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupPresentCapabilitiesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentCapabilitiesKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentCapabilitiesKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetDeviceGroupSurfacePresentModesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupSurfacePresentModesKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupSurfacePresentModesKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupSurfacePresentModesKHR-pModes-parameter",\r
+ "text": " <code>pModes</code> <strong class=\"purple\">must</strong> be a valid pointer to a <a href=\"#VkDeviceGroupPresentModeFlagsKHR\">VkDeviceGroupPresentModeFlagsKHR</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetDeviceGroupSurfacePresentModesKHR-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDevicePresentRectanglesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDevicePresentRectanglesKHR-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDevicePresentRectanglesKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDevicePresentRectanglesKHR-pRectCount-parameter",\r
+ "text": " <code>pRectCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDevicePresentRectanglesKHR-pRects-parameter",\r
+ "text": " If the value referenced by <code>pRectCount</code> is not <code>0</code>, and <code>pRects</code> is not <code>NULL</code>, <code>pRects</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pRectCount</code> <code>VkRect2D</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDevicePresentRectanglesKHR-commonparent",\r
+ "text": " Both of <code>physicalDevice</code>, and <code>surface</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetRefreshCycleDurationGOOGLE": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_GOOGLE_display_timing)": [\r
+ {\r
+ "vuid": "VUID-vkGetRefreshCycleDurationGOOGLE-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRefreshCycleDurationGOOGLE-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRefreshCycleDurationGOOGLE-pDisplayTimingProperties-parameter",\r
+ "text": " <code>pDisplayTimingProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkRefreshCycleDurationGOOGLE</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetRefreshCycleDurationGOOGLE-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPastPresentationTimingGOOGLE": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_GOOGLE_display_timing)": [\r
+ {\r
+ "vuid": "VUID-vkGetPastPresentationTimingGOOGLE-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPastPresentationTimingGOOGLE-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPastPresentationTimingGOOGLE-pPresentationTimingCount-parameter",\r
+ "text": " <code>pPresentationTimingCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPastPresentationTimingGOOGLE-pPresentationTimings-parameter",\r
+ "text": " If the value referenced by <code>pPresentationTimingCount</code> is not <code>0</code>, and <code>pPresentationTimings</code> is not <code>NULL</code>, <code>pPresentationTimings</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPresentationTimingCount</code> <code>VkPastPresentationTimingGOOGLE</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPastPresentationTimingGOOGLE-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetSwapchainStatusKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainStatusKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainStatusKHR-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainStatusKHR-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateSwapchainKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkCreateSwapchainKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSwapchainKHR-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkSwapchainCreateInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSwapchainKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSwapchainKHR-pSwapchain-parameter",\r
+ "text": " <code>pSwapchain</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkSwapchainKHR</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkSwapchainCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-surface-01270",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a surface that is supported by the device as determined using <code>vkGetPhysicalDeviceSurfaceSupportKHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-minImageCount-01271",\r
+ "text": " <code>minImageCount</code> <strong class=\"purple\">must</strong> be greater than or equal to the value returned in the <code>minImageCount</code> member of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-minImageCount-01272",\r
+ "text": " <code>minImageCount</code> <strong class=\"purple\">must</strong> be less than or equal to the value returned in the <code>maxImageCount</code> member of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface if the returned <code>maxImageCount</code> is not zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageFormat-01273",\r
+ "text": " <code>imageFormat</code> and <code>imageColorSpace</code> <strong class=\"purple\">must</strong> match the <code>format</code> and <code>colorSpace</code> members, respectively, of one of the <code>VkSurfaceFormatKHR</code> structures returned by <code>vkGetPhysicalDeviceSurfaceFormatsKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageExtent-01274",\r
+ "text": " <code>imageExtent</code> <strong class=\"purple\">must</strong> be between <code>minImageExtent</code> and <code>maxImageExtent</code>, inclusive, where <code>minImageExtent</code> and <code>maxImageExtent</code> are members of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageExtent-01689",\r
+ "text": " <code>imageExtent</code> members <code>width</code> and <code>height</code> <strong class=\"purple\">must</strong> both be non-zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageArrayLayers-01275",\r
+ "text": " <code>imageArrayLayers</code> <strong class=\"purple\">must</strong> be greater than <code>0</code> and less than or equal to the <code>maxImageArrayLayers</code> member of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageSharingMode-01277",\r
+ "text": " If <code>imageSharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>queueFamilyIndexCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageSharingMode-01278",\r
+ "text": " If <code>imageSharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, <code>queueFamilyIndexCount</code> <strong class=\"purple\">must</strong> be greater than <code>1</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-preTransform-01279",\r
+ "text": " <code>preTransform</code> <strong class=\"purple\">must</strong> be one of the bits present in the <code>supportedTransforms</code> member of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-compositeAlpha-01280",\r
+ "text": " <code>compositeAlpha</code> <strong class=\"purple\">must</strong> be one of the bits present in the <code>supportedCompositeAlpha</code> member of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-presentMode-01281",\r
+ "text": " <code>presentMode</code> <strong class=\"purple\">must</strong> be one of the <a href=\"#VkPresentModeKHR\">VkPresentModeKHR</a> values returned by <code>vkGetPhysicalDeviceSurfacePresentModesKHR</code> for the surface"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-oldSwapchain-01933",\r
+ "text": " If <code>oldSwapchain</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>oldSwapchain</code> <strong class=\"purple\">must</strong> be a non-retired swapchain associated with native window referred to by <code>surface</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageFormat-01778",\r
+ "text": " <code>imageFormat</code>, <code>imageUsage</code>, <code>imageExtent</code>, and <code>imageArrayLayers</code> <strong class=\"purple\">must</strong> be supported for <code>VK_IMAGE_TYPE_2D</code> <code>VK_IMAGE_TILING_OPTIMAL</code> images as reported by <a href=\"#vkGetPhysicalDeviceImageFormatProperties\">vkGetPhysicalDeviceImageFormatProperties</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceGroupSwapchainCreateInfoKHR\">VkDeviceGroupSwapchainCreateInfoKHR</a> or <a href=\"#VkSwapchainCounterCreateInfoEXT\">VkSwapchainCounterCreateInfoEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSwapchainCreateFlagBitsKHR\">VkSwapchainCreateFlagBitsKHR</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-surface-parameter",\r
+ "text": " <code>surface</code> <strong class=\"purple\">must</strong> be a valid <code>VkSurfaceKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageFormat-parameter",\r
+ "text": " <code>imageFormat</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageColorSpace-parameter",\r
+ "text": " <code>imageColorSpace</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkColorSpaceKHR\">VkColorSpaceKHR</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageUsage-parameter",\r
+ "text": " <code>imageUsage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageUsage-requiredbitmask",\r
+ "text": " <code>imageUsage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageSharingMode-parameter",\r
+ "text": " <code>imageSharingMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSharingMode\">VkSharingMode</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-preTransform-parameter",\r
+ "text": " <code>preTransform</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSurfaceTransformFlagBitsKHR\">VkSurfaceTransformFlagBitsKHR</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-compositeAlpha-parameter",\r
+ "text": " <code>compositeAlpha</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkCompositeAlphaFlagBitsKHR\">VkCompositeAlphaFlagBitsKHR</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-presentMode-parameter",\r
+ "text": " <code>presentMode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkPresentModeKHR\">VkPresentModeKHR</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-oldSwapchain-parameter",\r
+ "text": " If <code>oldSwapchain</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>oldSwapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-oldSwapchain-parent",\r
+ "text": " If <code>oldSwapchain</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>surface</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-commonparent",\r
+ "text": " Both of <code>oldSwapchain</code>, and <code>surface</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-minImageCount-01383",\r
+ "text": " <code>minImageCount</code> <strong class=\"purple\">must</strong> be <code>1</code> if <code>presentMode</code> is either <code>VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR</code> or <code>VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-presentMode-01427",\r
+ "text": " If <code>presentMode</code> is <code>VK_PRESENT_MODE_IMMEDIATE_KHR</code>, <code>VK_PRESENT_MODE_MAILBOX_KHR</code>, <code>VK_PRESENT_MODE_FIFO_KHR</code> or <code>VK_PRESENT_MODE_FIFO_RELAXED_KHR</code>, <code>imageUsage</code> <strong class=\"purple\">must</strong> be a subset of the supported usage flags present in the <code>supportedUsageFlags</code> member of the <a href=\"#VkSurfaceCapabilitiesKHR\">VkSurfaceCapabilitiesKHR</a> structure returned by <a href=\"#vkGetPhysicalDeviceSurfaceCapabilitiesKHR\">vkGetPhysicalDeviceSurfaceCapabilitiesKHR</a> for <code>surface</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageUsage-01384",\r
+ "text": " If <code>presentMode</code> is <code>VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR</code> or <code>VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR</code>, <code>imageUsage</code> <strong class=\"purple\">must</strong> be a subset of the supported usage flags present in the <code>sharedPresentSupportedUsageFlags</code> member of the <a href=\"#VkSharedPresentSurfaceCapabilitiesKHR\">VkSharedPresentSurfaceCapabilitiesKHR</a> structure returned by <a href=\"#vkGetPhysicalDeviceSurfaceCapabilities2KHR\">vkGetPhysicalDeviceSurfaceCapabilities2KHR</a> for <code>surface</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageUsage-01276",\r
+ "text": " <code>imageUsage</code> <strong class=\"purple\">must</strong> be a subset of the supported usage flags present in the <code>supportedUsageFlags</code> member of the <code>VkSurfaceCapabilitiesKHR</code> structure returned by <code>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</code> for the surface"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+!(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageSharingMode-01393",\r
+ "text": " If <code>imageSharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, each element of <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be unique and <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties\">vkGetPhysicalDeviceQueueFamilyProperties</a> for the <code>physicalDevice</code> that was used to create <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-imageSharingMode-01428",\r
+ "text": " If <code>imageSharingMode</code> is <code>VK_SHARING_MODE_CONCURRENT</code>, each element of <code>pQueueFamilyIndices</code> <strong class=\"purple\">must</strong> be unique and <strong class=\"purple\">must</strong> be less than <code>pQueueFamilyPropertyCount</code> returned by either <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties\">vkGetPhysicalDeviceQueueFamilyProperties</a> or <a href=\"#vkGetPhysicalDeviceQueueFamilyProperties2\">vkGetPhysicalDeviceQueueFamilyProperties2</a> for the <code>physicalDevice</code> that was used to create <code>device</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCreateInfoKHR-physicalDeviceCount-01429",\r
+ "text": " If the logical device was created with <a href=\"#VkDeviceGroupDeviceCreateInfo\">VkDeviceGroupDeviceCreateInfo</a>::<code>physicalDeviceCount</code> equal to 1, <code>flags</code> <strong class=\"purple\">must</strong> not contain <code>VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupSwapchainCreateInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSwapchainCreateInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSwapchainCreateInfoKHR-modes-parameter",\r
+ "text": " <code>modes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDeviceGroupPresentModeFlagBitsKHR\">VkDeviceGroupPresentModeFlagBitsKHR</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupSwapchainCreateInfoKHR-modes-requiredbitmask",\r
+ "text": " <code>modes</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSwapchainCounterCreateInfoEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-VkSwapchainCounterCreateInfoEXT-surfaceCounters-01244",\r
+ "text": " The bits in <code>surfaceCounters</code> <strong class=\"purple\">must</strong> be supported by <a href=\"#VkSwapchainCreateInfoKHR\">VkSwapchainCreateInfoKHR</a>::<code>surface</code>, as reported by <a href=\"#vkGetPhysicalDeviceSurfaceCapabilities2EXT\">vkGetPhysicalDeviceSurfaceCapabilities2EXT</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCounterCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkSwapchainCounterCreateInfoEXT-surfaceCounters-parameter",\r
+ "text": " <code>surfaceCounters</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkSurfaceCounterFlagBitsEXT\">VkSurfaceCounterFlagBitsEXT</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetSwapchainCounterEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_EXT_display_control)": [\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainCounterEXT-swapchain-01245",\r
+ "text": " One or more present commands on <code>swapchain</code> <strong class=\"purple\">must</strong> have been processed by the presentation engine."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainCounterEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainCounterEXT-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainCounterEXT-counter-parameter",\r
+ "text": " <code>counter</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSurfaceCounterFlagBitsEXT\">VkSurfaceCounterFlagBitsEXT</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainCounterEXT-pCounterValue-parameter",\r
+ "text": " <code>pCounterValue</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint64_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainCounterEXT-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroySwapchainKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-swapchain-01282",\r
+ "text": " All uses of presentable images acquired from <code>swapchain</code> <strong class=\"purple\">must</strong> have completed execution"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-swapchain-01283",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>swapchain</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-swapchain-01284",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>swapchain</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-swapchain-parameter",\r
+ "text": " If <code>swapchain</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroySwapchainKHR-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateSharedSwapchainsKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_display_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkCreateSharedSwapchainsKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSharedSwapchainsKHR-pCreateInfos-parameter",\r
+ "text": " <code>pCreateInfos</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> valid <code>VkSwapchainCreateInfoKHR</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSharedSwapchainsKHR-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSharedSwapchainsKHR-pSwapchains-parameter",\r
+ "text": " <code>pSwapchains</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> <code>VkSwapchainKHR</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateSharedSwapchainsKHR-swapchainCount-arraylength",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetSwapchainImagesKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainImagesKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainImagesKHR-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainImagesKHR-pSwapchainImageCount-parameter",\r
+ "text": " <code>pSwapchainImageCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainImagesKHR-pSwapchainImages-parameter",\r
+ "text": " If the value referenced by <code>pSwapchainImageCount</code> is not <code>0</code>, and <code>pSwapchainImages</code> is not <code>NULL</code>, <code>pSwapchainImages</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pSwapchainImageCount</code> <code>VkImage</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetSwapchainImagesKHR-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkAcquireNextImageKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-swapchain-01285",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> not be in the retired state"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-semaphore-01286",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> it <strong class=\"purple\">must</strong> be unsignaled"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-semaphore-01779",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> it <strong class=\"purple\">must</strong> not have any uncompleted signal or wait operations pending"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-fence-01287",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> it <strong class=\"purple\">must</strong> be unsignaled and <strong class=\"purple\">must</strong> not be associated with any other queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-semaphore-01780",\r
+ "text": " <code>semaphore</code> and <code>fence</code> <strong class=\"purple\">must</strong> not both be equal to <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-swapchain-01802",\r
+ "text": " If the number of currently acquired images is greater than the difference between the number of images in <code>swapchain</code> and the value of <a href=\"#VkSurfaceCapabilitiesKHR\">VkSurfaceCapabilitiesKHR</a>::<code>minImageCount</code> as returned by a call to <a href=\"#vkGetPhysicalDeviceSurfaceCapabilities2KHR\">vkGetPhysicalDeviceSurfaceCapabilities2KHR</a> with the <code>surface</code> used to create <code>swapchain</code>, <code>timeout</code> <strong class=\"purple\">must</strong> not be <code>UINT64_MAX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-semaphore-parameter",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-fence-parameter",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-pImageIndex-parameter",\r
+ "text": " <code>pImageIndex</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-semaphore-parent",\r
+ "text": " If <code>semaphore</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-fence-parent",\r
+ "text": " If <code>fence</code> is a valid handle, it <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>device</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImageKHR-commonparent",\r
+ "text": " Both of <code>device</code>, and <code>swapchain</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkAcquireNextImage2KHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImage2KHR-swapchain-01803",\r
+ "text": " If the number of currently acquired images is greater than the difference between the number of images in the <code>swapchain</code> member of <code>pAcquireInfo</code> and the value of <a href=\"#VkSurfaceCapabilitiesKHR\">VkSurfaceCapabilitiesKHR</a>::<code>minImageCount</code> as returned by a call to <a href=\"#vkGetPhysicalDeviceSurfaceCapabilities2KHR\">vkGetPhysicalDeviceSurfaceCapabilities2KHR</a> with the <code>surface</code> used to create <code>swapchain</code>, the <code>timeout</code> member of <code>pAcquireInfo</code> <strong class=\"purple\">must</strong> not be <code>UINT64_MAX</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImage2KHR-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImage2KHR-pAcquireInfo-parameter",\r
+ "text": " <code>pAcquireInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAcquireNextImageInfoKHR</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkAcquireNextImage2KHR-pImageIndex-parameter",\r
+ "text": " <code>pImageIndex</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkAcquireNextImageInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-swapchain-01675",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> not be in the retired state"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-semaphore-01288",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> it <strong class=\"purple\">must</strong> be unsignaled"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-semaphore-01781",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> it <strong class=\"purple\">must</strong> not have any uncompleted signal or wait operations pending"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-fence-01289",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a> it <strong class=\"purple\">must</strong> be unsignaled and <strong class=\"purple\">must</strong> not be associated with any other queue command that has not yet completed execution on that queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-semaphore-01782",\r
+ "text": " <code>semaphore</code> and <code>fence</code> <strong class=\"purple\">must</strong> not both be equal to <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-deviceMask-01290",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> be a valid device mask"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-deviceMask-01291",\r
+ "text": " <code>deviceMask</code> <strong class=\"purple\">must</strong> not be zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-semaphore-01804",\r
+ "text": " <code>semaphore</code> and <code>fence</code> <strong class=\"purple\">must</strong> not both be equal to <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-swapchain-parameter",\r
+ "text": " <code>swapchain</code> <strong class=\"purple\">must</strong> be a valid <code>VkSwapchainKHR</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-semaphore-parameter",\r
+ "text": " If <code>semaphore</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>semaphore</code> <strong class=\"purple\">must</strong> be a valid <code>VkSemaphore</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-fence-parameter",\r
+ "text": " If <code>fence</code> is not <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>, <code>fence</code> <strong class=\"purple\">must</strong> be a valid <code>VkFence</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkAcquireNextImageInfoKHR-commonparent",\r
+ "text": " Each of <code>fence</code>, <code>semaphore</code>, and <code>swapchain</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkQueuePresentKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkQueuePresentKHR-pSwapchains-01292",\r
+ "text": " Each element of <code>pSwapchains</code> member of <code>pPresentInfo</code> <strong class=\"purple\">must</strong> be a swapchain that is created for a surface for which presentation is supported from <code>queue</code> as determined using a call to <code>vkGetPhysicalDeviceSurfaceSupportKHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueuePresentKHR-pWaitSemaphores-01294",\r
+ "text": " When a semaphore unsignal operation defined by the elements of the <code>pWaitSemaphores</code> member of <code>pPresentInfo</code> executes on <code>queue</code>, no other queue <strong class=\"purple\">must</strong> be waiting on the same semaphore."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueuePresentKHR-pWaitSemaphores-01295",\r
+ "text": " All elements of the <code>pWaitSemaphores</code> member of <code>pPresentInfo</code> <strong class=\"purple\">must</strong> be semaphores that are signaled, or have &amp;lt;&amp;lt;synchronization-semaphores-signaling, semaphore signal operations&amp;gt;&amp;gt; previously submitted for execution."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueuePresentKHR-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueuePresentKHR-pPresentInfo-parameter",\r
+ "text": " <code>pPresentInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPresentInfoKHR</code> structure"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_display_swapchain)": [\r
+ {\r
+ "vuid": "VUID-vkQueuePresentKHR-pSwapchains-01293",\r
+ "text": " If more than one member of <code>pSwapchains</code> was created from a display surface, all display surfaces referenced that refer to the same display <strong class=\"purple\">must</strong> use the same display mode"\r
+ }\r
+ ]\r
+ },\r
+ "VkPresentInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+!(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pImageIndices-01296",\r
+ "text": " Each element of <code>pImageIndices</code> <strong class=\"purple\">must</strong> be the index of a presentable image acquired from the swapchain specified by the corresponding element of the <code>pSwapchains</code> array, and the presented image subresource <strong class=\"purple\">must</strong> be in the <code>VK_IMAGE_LAYOUT_PRESENT_SRC_KHR</code> layout at the time the operation is executed on a <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_shared_presentable_image)": [\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pImageIndices-01430",\r
+ "text": " Each element of <code>pImageIndices</code> <strong class=\"purple\">must</strong> be the index of a presentable image acquired from the swapchain specified by the corresponding element of the <code>pSwapchains</code> array, and the presented image subresource <strong class=\"purple\">must</strong> be in the <code>VK_IMAGE_LAYOUT_PRESENT_SRC_KHR</code> or <code>VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR</code> layout at the time the operation is executed on a <code>VkDevice</code>"\r
+ }\r
+ ],\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)": [\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PRESENT_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkDeviceGroupPresentInfoKHR\">VkDeviceGroupPresentInfoKHR</a>, <a href=\"#VkDisplayPresentInfoKHR\">VkDisplayPresentInfoKHR</a>, <a href=\"#VkPresentRegionsKHR\">VkPresentRegionsKHR</a>, or <a href=\"#VkPresentTimesInfoGOOGLE\">VkPresentTimesInfoGOOGLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pWaitSemaphores-parameter",\r
+ "text": " If <code>waitSemaphoreCount</code> is not <code>0</code>, <code>pWaitSemaphores</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>waitSemaphoreCount</code> valid <code>VkSemaphore</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pSwapchains-parameter",\r
+ "text": " <code>pSwapchains</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> valid <code>VkSwapchainKHR</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pImageIndices-parameter",\r
+ "text": " <code>pImageIndices</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-pResults-parameter",\r
+ "text": " If <code>pResults</code> is not <code>NULL</code>, <code>pResults</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> <a href=\"#VkResult\">VkResult</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-swapchainCount-arraylength",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentInfoKHR-commonparent",\r
+ "text": " Both of the elements of <code>pSwapchains</code>, and the elements of <code>pWaitSemaphores</code> that are valid handles <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPresentRegionsKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_incremental_present)": [\r
+ {\r
+ "vuid": "VUID-VkPresentRegionsKHR-swapchainCount-01260",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be the same value as <code>VkPresentInfoKHR</code>::<code>swapchainCount</code>, where <code>VkPresentInfoKHR</code> is in the pNext-chain of this <code>VkPresentRegionsKHR</code> structure."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentRegionsKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentRegionsKHR-pRegions-parameter",\r
+ "text": " If <code>pRegions</code> is not <code>NULL</code>, <code>pRegions</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> valid <code>VkPresentRegionKHR</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentRegionsKHR-swapchainCount-arraylength",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPresentRegionKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_incremental_present)": [\r
+ {\r
+ "vuid": "VUID-VkPresentRegionKHR-pRectangles-parameter",\r
+ "text": " If <code>rectangleCount</code> is not <code>0</code>, and <code>pRectangles</code> is not <code>NULL</code>, <code>pRectangles</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>rectangleCount</code> <code>VkRectLayerKHR</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "VkRectLayerKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_incremental_present)": [\r
+ {\r
+ "vuid": "VUID-VkRectLayerKHR-offset-01261",\r
+ "text": " The sum of <code>offset</code> and <code>extent</code> <strong class=\"purple\">must</strong> be no greater than the <code>imageExtent</code> member of the <code>VkSwapchainCreateInfoKHR</code> structure given to <a href=\"#vkCreateSwapchainKHR\">vkCreateSwapchainKHR</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkRectLayerKHR-layer-01262",\r
+ "text": " <code>layer</code> <strong class=\"purple\">must</strong> be less than <code>imageArrayLayers</code> member of the <code>VkSwapchainCreateInfoKHR</code> structure given to <a href=\"#vkCreateSwapchainKHR\">vkCreateSwapchainKHR</a>."\r
+ }\r
+ ]\r
+ },\r
+ "VkDisplayPresentInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_KHR_display_swapchain)": [\r
+ {\r
+ "vuid": "VUID-VkDisplayPresentInfoKHR-srcRect-01257",\r
+ "text": " <code>srcRect</code> <strong class=\"purple\">must</strong> specify a rectangular region that is a subset of the image being presented"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayPresentInfoKHR-dstRect-01258",\r
+ "text": " <code>dstRect</code> <strong class=\"purple\">must</strong> specify a rectangular region that is a subset of the <code>visibleRegion</code> parameter of the display mode the swapchain being presented uses"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayPresentInfoKHR-persistentContent-01259",\r
+ "text": " If the <code>persistentContent</code> member of the <code>VkDisplayPropertiesKHR</code> structure returned by <code>vkGetPhysicalDeviceDisplayPropertiesKHR</code> for the display the present operation targets then <code>persistent</code> <strong class=\"purple\">must</strong> be <code>VK_FALSE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDisplayPresentInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDeviceGroupPresentInfoKHR": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_VERSION_1_1,VK_KHR_device_group)": [\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-swapchainCount-01297",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> equal <code>0</code> or <a href=\"#VkPresentInfoKHR\">VkPresentInfoKHR</a>::<code>swapchainCount</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-mode-01298",\r
+ "text": " If <code>mode</code> is <code>VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR</code>, then each element of <code>pDeviceMasks</code> <strong class=\"purple\">must</strong> have exactly one bit set, and the corresponding element of <a href=\"#VkDeviceGroupPresentCapabilitiesKHR\">VkDeviceGroupPresentCapabilitiesKHR</a>::<code>presentMask</code> <strong class=\"purple\">must</strong> be non-zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-mode-01299",\r
+ "text": " If <code>mode</code> is <code>VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR</code>, then each element of <code>pDeviceMasks</code> <strong class=\"purple\">must</strong> have exactly one bit set, and some physical device in the logical device <strong class=\"purple\">must</strong> include that bit in its <a href=\"#VkDeviceGroupPresentCapabilitiesKHR\">VkDeviceGroupPresentCapabilitiesKHR</a>::<code>presentMask</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-mode-01300",\r
+ "text": " If <code>mode</code> is <code>VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR</code>, then each element of <code>pDeviceMasks</code> <strong class=\"purple\">must</strong> have a value for which all set bits are set in one of the elements of <a href=\"#VkDeviceGroupPresentCapabilitiesKHR\">VkDeviceGroupPresentCapabilitiesKHR</a>::<code>presentMask</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-mode-01301",\r
+ "text": " If <code>mode</code> is <code>VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR</code>, then for each bit set in each element of <code>pDeviceMasks</code>, the corresponding element of <a href=\"#VkDeviceGroupPresentCapabilitiesKHR\">VkDeviceGroupPresentCapabilitiesKHR</a>::<code>presentMask</code> <strong class=\"purple\">must</strong> be non-zero"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-pDeviceMasks-01302",\r
+ "text": " The value of each element of <code>pDeviceMasks</code> <strong class=\"purple\">must</strong> be equal to the device mask passed in <a href=\"#VkAcquireNextImageInfoKHR\">VkAcquireNextImageInfoKHR</a>::<code>deviceMask</code> when the image index was last acquired"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-mode-01303",\r
+ "text": " <code>mode</code> <strong class=\"purple\">must</strong> have exactly one bit set, and that bit <strong class=\"purple\">must</strong> have been included in <a href=\"#VkDeviceGroupSwapchainCreateInfoKHR\">VkDeviceGroupSwapchainCreateInfoKHR</a>::<code>modes</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-pDeviceMasks-parameter",\r
+ "text": " If <code>swapchainCount</code> is not <code>0</code>, <code>pDeviceMasks</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> <code>uint32_t</code> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDeviceGroupPresentInfoKHR-mode-parameter",\r
+ "text": " <code>mode</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDeviceGroupPresentModeFlagBitsKHR\">VkDeviceGroupPresentModeFlagBitsKHR</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkPresentTimesInfoGOOGLE": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_GOOGLE_display_timing)": [\r
+ {\r
+ "vuid": "VUID-VkPresentTimesInfoGOOGLE-swapchainCount-01247",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be the same value as <code>VkPresentInfoKHR</code>::<code>swapchainCount</code>, where <code>VkPresentInfoKHR</code> is in the <code>pNext</code> chain of this <code>VkPresentTimesInfoGOOGLE</code> structure."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentTimesInfoGOOGLE-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentTimesInfoGOOGLE-pTimes-parameter",\r
+ "text": " If <code>pTimes</code> is not <code>NULL</code>, <code>pTimes</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> <code>VkPresentTimeGOOGLE</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPresentTimesInfoGOOGLE-swapchainCount-arraylength",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkSetHdrMetadataEXT": {\r
+ "(VK_KHR_surface)+(VK_KHR_swapchain)+(VK_EXT_hdr_metadata)": [\r
+ {\r
+ "vuid": "VUID-vkSetHdrMetadataEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetHdrMetadataEXT-pSwapchains-parameter",\r
+ "text": " <code>pSwapchains</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> valid <code>VkSwapchainKHR</code> handles"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetHdrMetadataEXT-pMetadata-parameter",\r
+ "text": " <code>pMetadata</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>swapchainCount</code> valid <code>VkHdrMetadataEXT</code> structures"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetHdrMetadataEXT-swapchainCount-arraylength",\r
+ "text": " <code>swapchainCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetHdrMetadataEXT-commonparent",\r
+ "text": " Both of <code>device</code>, and the elements of <code>pSwapchains</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from the same <code>VkInstance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumerateInstanceLayerProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkEnumerateInstanceLayerProperties-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateInstanceLayerProperties-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkLayerProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumerateDeviceLayerProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceLayerProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceLayerProperties-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceLayerProperties-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkLayerProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumerateInstanceExtensionProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkEnumerateInstanceExtensionProperties-pLayerName-parameter",\r
+ "text": " If <code>pLayerName</code> is not <code>NULL</code>, <code>pLayerName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateInstanceExtensionProperties-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateInstanceExtensionProperties-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkExtensionProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkEnumerateDeviceExtensionProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceExtensionProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceExtensionProperties-pLayerName-parameter",\r
+ "text": " If <code>pLayerName</code> is not <code>NULL</code>, <code>pLayerName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceExtensionProperties-pPropertyCount-parameter",\r
+ "text": " <code>pPropertyCount</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>uint32_t</code> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkEnumerateDeviceExtensionProperties-pProperties-parameter",\r
+ "text": " If the value referenced by <code>pPropertyCount</code> is not <code>0</code>, and <code>pProperties</code> is not <code>NULL</code>, <code>pProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>pPropertyCount</code> <code>VkExtensionProperties</code> structures"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceFeatures": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFeatures-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFeatures-pFeatures-parameter",\r
+ "text": " <code>pFeatures</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPhysicalDeviceFeatures</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceFeatures2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFeatures2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFeatures2-pFeatures-parameter",\r
+ "text": " <code>pFeatures</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkPhysicalDeviceFeatures2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceFeatures2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceFeatures2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceVariablePointerFeatures": {\r
+ "(VK_VERSION_1_1,VK_KHR_variable_pointers)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceVariablePointerFeatures-variablePointers-01431",\r
+ "text": " If <code>variablePointers</code> is enabled then <code>variablePointersStorageBuffer</code> <strong class=\"purple\">must</strong> also be enabled."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceVariablePointerFeatures-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceMultiviewFeatures": {\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMultiviewFeatures-multiviewGeometryShader-00580",\r
+ "text": " If <code>multiviewGeometryShader</code> is enabled then <code>multiview</code> <strong class=\"purple\">must</strong> also be enabled."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMultiviewFeatures-multiviewTessellationShader-00581",\r
+ "text": " If <code>multiviewTessellationShader</code> is enabled then <code>multiview</code> <strong class=\"purple\">must</strong> also be enabled."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMultiviewFeatures-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDevice16BitStorageFeatures": {\r
+ "(VK_VERSION_1_1,VK_KHR_16bit_storage)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDevice16BitStorageFeatures-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceSamplerYcbcrConversionFeatures": {\r
+ "(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSamplerYcbcrConversionFeatures-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceProtectedMemoryFeatures": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceProtectedMemoryFeatures-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT": {\r
+ "(VK_EXT_blend_operation_advanced)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceShaderDrawParameterFeatures": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceShaderDrawParameterFeatures-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceDescriptorIndexingFeaturesEXT": {\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceDescriptorIndexingFeaturesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_FEATURES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDevicePushDescriptorPropertiesKHR": {\r
+ "(VK_KHR_push_descriptor)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDevicePushDescriptorPropertiesKHR-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceMultiviewProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_multiview)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMultiviewProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceDiscardRectanglePropertiesEXT": {\r
+ "(VK_EXT_discard_rectangles)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceDiscardRectanglePropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceSampleLocationsPropertiesEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSampleLocationsPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceExternalMemoryHostPropertiesEXT": {\r
+ "(VK_EXT_external_memory_host)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalMemoryHostPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX": {\r
+ "(VK_NVX_multiview_per_view_attributes)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDevicePointClippingProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDevicePointClippingProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceSubgroupProperties": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSubgroupProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT": {\r
+ "(VK_EXT_blend_operation_advanced)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT": {\r
+ "(VK_EXT_vertex_attribute_divisor)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT": {\r
+ "(VK_EXT_sampler_filter_minmax)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceProtectedMemoryProperties": {\r
+ "(VK_VERSION_1_1)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceProtectedMemoryProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceMaintenance3Properties": {\r
+ "(VK_VERSION_1_1,VK_KHR_maintenance3)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceMaintenance3Properties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceDescriptorIndexingPropertiesEXT": {\r
+ "(VK_EXT_descriptor_indexing)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceDescriptorIndexingPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceConservativeRasterizationPropertiesEXT": {\r
+ "(VK_EXT_conservative_rasterization)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceConservativeRasterizationPropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceShaderCorePropertiesAMD": {\r
+ "(VK_AMD_shader_core_properties)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceShaderCorePropertiesAMD-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_CORE_PROPERTIES_AMD</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceMultisamplePropertiesEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMultisamplePropertiesEXT-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMultisamplePropertiesEXT-samples-parameter",\r
+ "text": " <code>samples</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkSampleCountFlagBits\">VkSampleCountFlagBits</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceMultisamplePropertiesEXT-pMultisampleProperties-parameter",\r
+ "text": " <code>pMultisampleProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkMultisamplePropertiesEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkMultisamplePropertiesEXT": {\r
+ "(VK_EXT_sample_locations)": [\r
+ {\r
+ "vuid": "VUID-VkMultisamplePropertiesEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkMultisamplePropertiesEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceFormatProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFormatProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFormatProperties-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFormatProperties-pFormatProperties-parameter",\r
+ "text": " <code>pFormatProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkFormatProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceFormatProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFormatProperties2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFormatProperties2-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceFormatProperties2-pFormatProperties-parameter",\r
+ "text": " <code>pFormatProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkFormatProperties2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkFormatProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkFormatProperties2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkFormatProperties2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceImageFormatProperties": {\r
+ "core": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageType\">VkImageType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-tiling-parameter",\r
+ "text": " <code>tiling</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageTiling\">VkImageTiling</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageCreateFlagBits\">VkImageCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties-pImageFormatProperties-parameter",\r
+ "text": " <code>pImageFormatProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkImageFormatProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceExternalImageFormatPropertiesNV": {\r
+ "(VK_NV_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageType\">VkImageType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-tiling-parameter",\r
+ "text": " <code>tiling</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageTiling\">VkImageTiling</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageCreateFlagBits\">VkImageCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-externalHandleType-parameter",\r
+ "text": " <code>externalHandleType</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkExternalMemoryHandleTypeFlagBitsNV\">VkExternalMemoryHandleTypeFlagBitsNV</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalImageFormatPropertiesNV-pExternalImageFormatProperties-parameter",\r
+ "text": " <code>pExternalImageFormatProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkExternalImageFormatPropertiesNV</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceImageFormatProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)+(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties2-pNext-01868",\r
+ "text": " If the <code>pNext</code> chain of <code>pImageFormatProperties</code> contains an instance of <a href=\"#VkAndroidHardwareBufferUsageANDROID\">VkAndroidHardwareBufferUsageANDROID</a>, the <code>pNext</code> chain of <code>pImageFormatInfo</code> <strong class=\"purple\">must</strong> contain an instance of <a href=\"#VkPhysicalDeviceExternalImageFormatInfo\">VkPhysicalDeviceExternalImageFormatInfo</a> with <code>handleType</code> set to <code>VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID</code>."\r
+ }\r
+ ],\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties2-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties2-pImageFormatInfo-parameter",\r
+ "text": " <code>pImageFormatInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceImageFormatInfo2</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceImageFormatProperties2-pImageFormatProperties-parameter",\r
+ "text": " <code>pImageFormatProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkImageFormatProperties2</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceImageFormatInfo2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkPhysicalDeviceExternalImageFormatInfo\">VkPhysicalDeviceExternalImageFormatInfo</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-format-parameter",\r
+ "text": " <code>format</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkFormat\">VkFormat</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-type-parameter",\r
+ "text": " <code>type</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageType\">VkImageType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-tiling-parameter",\r
+ "text": " <code>tiling</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkImageTiling\">VkImageTiling</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageUsageFlagBits\">VkImageUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceImageFormatInfo2-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkImageCreateFlagBits\">VkImageCreateFlagBits</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "VkImageFormatProperties2": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)": [\r
+ {\r
+ "vuid": "VUID-VkImageFormatProperties2-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageFormatProperties2-pNext-pNext",\r
+ "text": " Each <code>pNext</code> member of any structure (including this one) in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be either <code>NULL</code> or a pointer to a valid instance of <a href=\"#VkAndroidHardwareBufferUsageANDROID\">VkAndroidHardwareBufferUsageANDROID</a>, <a href=\"#VkExternalImageFormatProperties\">VkExternalImageFormatProperties</a>, <a href=\"#VkSamplerYcbcrConversionImageFormatProperties\">VkSamplerYcbcrConversionImageFormatProperties</a>, or <a href=\"#VkTextureLODGatherFormatPropertiesAMD\">VkTextureLODGatherFormatPropertiesAMD</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkImageFormatProperties2-sType-unique",\r
+ "text": " Each <code>sType</code> member in the <code>pNext</code> chain <strong class=\"purple\">must</strong> be unique"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceExternalImageFormatInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)+(VK_VERSION_1_1,VK_KHR_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalImageFormatInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalImageFormatInfo-handleType-parameter",\r
+ "text": " If <code>handleType</code> is not <code>0</code>, <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalImageFormatProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)+(VK_VERSION_1_1,VK_KHR_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkExternalImageFormatProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkSamplerYcbcrConversionImageFormatProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)+(VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion)": [\r
+ {\r
+ "vuid": "VUID-VkSamplerYcbcrConversionImageFormatProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkAndroidHardwareBufferUsageANDROID": {\r
+ "(VK_VERSION_1_1,VK_KHR_get_physical_device_properties2)+(VK_ANDROID_external_memory_android_hardware_buffer)": [\r
+ {\r
+ "vuid": "VUID-VkAndroidHardwareBufferUsageANDROID-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_USAGE_ANDROID</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceExternalBufferProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalBufferProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalBufferProperties-pExternalBufferInfo-parameter",\r
+ "text": " <code>pExternalBufferInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceExternalBufferInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalBufferProperties-pExternalBufferProperties-parameter",\r
+ "text": " <code>pExternalBufferProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkExternalBufferProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceExternalBufferInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalBufferInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalBufferInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalBufferInfo-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkBufferCreateFlagBits\">VkBufferCreateFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalBufferInfo-usage-parameter",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkBufferUsageFlagBits\">VkBufferUsageFlagBits</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalBufferInfo-usage-requiredbitmask",\r
+ "text": " <code>usage</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalBufferInfo-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalMemoryHandleTypeFlagBits\">VkExternalMemoryHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalBufferProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_memory_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkExternalBufferProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalBufferProperties-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceExternalSemaphoreProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_semaphore_capabilities)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalSemaphoreProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalSemaphoreProperties-pExternalSemaphoreInfo-parameter",\r
+ "text": " <code>pExternalSemaphoreInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceExternalSemaphoreInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalSemaphoreProperties-pExternalSemaphoreProperties-parameter",\r
+ "text": " <code>pExternalSemaphoreProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkExternalSemaphoreProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceExternalSemaphoreInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_semaphore_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalSemaphoreInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalSemaphoreInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalSemaphoreInfo-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalSemaphoreHandleTypeFlagBits\">VkExternalSemaphoreHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalSemaphoreProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_semaphore_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkExternalSemaphoreProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalSemaphoreProperties-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkGetPhysicalDeviceExternalFenceProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_fence_capabilities)": [\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalFenceProperties-physicalDevice-parameter",\r
+ "text": " <code>physicalDevice</code> <strong class=\"purple\">must</strong> be a valid <code>VkPhysicalDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalFenceProperties-pExternalFenceInfo-parameter",\r
+ "text": " <code>pExternalFenceInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkPhysicalDeviceExternalFenceInfo</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkGetPhysicalDeviceExternalFenceProperties-pExternalFenceProperties-parameter",\r
+ "text": " <code>pExternalFenceProperties</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkExternalFenceProperties</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkPhysicalDeviceExternalFenceInfo": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_fence_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalFenceInfo-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalFenceInfo-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkPhysicalDeviceExternalFenceInfo-handleType-parameter",\r
+ "text": " <code>handleType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkExternalFenceHandleTypeFlagBits\">VkExternalFenceHandleTypeFlagBits</a> value"\r
+ }\r
+ ]\r
+ },\r
+ "VkExternalFenceProperties": {\r
+ "(VK_VERSION_1_1,VK_KHR_external_fence_capabilities)": [\r
+ {\r
+ "vuid": "VUID-VkExternalFenceProperties-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkExternalFenceProperties-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkSetDebugUtilsObjectNameEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkSetDebugUtilsObjectNameEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetDebugUtilsObjectNameEXT-pNameInfo-parameter",\r
+ "text": " <code>pNameInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsObjectNameInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugUtilsObjectNameInfoEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-objectType-01905",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> not be <code>VK_OBJECT_TYPE_UNKNOWN</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-objectHandle-01906",\r
+ "text": " <code>objectHandle</code> <strong class=\"purple\">must</strong> not be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-objectHandle-01907",\r
+ "text": " <code>objectHandle</code> <strong class=\"purple\">must</strong> be a Vulkan object of the type associated with <code>objectType</code> as defined in &amp;lt;&amp;lt;debugging-object-types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-objectType-parameter",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectType\">VkObjectType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectNameInfoEXT-pObjectName-parameter",\r
+ "text": " If <code>pObjectName</code> is not <code>NULL</code>, <code>pObjectName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkSetDebugUtilsObjectTagEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkSetDebugUtilsObjectTagEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSetDebugUtilsObjectTagEXT-pTagInfo-parameter",\r
+ "text": " <code>pTagInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsObjectTagInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugUtilsObjectTagInfoEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-objectType-01908",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> not be <code>VK_OBJECT_TYPE_UNKNOWN</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-objectHandle-01909",\r
+ "text": " <code>objectHandle</code> <strong class=\"purple\">must</strong> not be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-objectHandle-01910",\r
+ "text": " <code>objectHandle</code> <strong class=\"purple\">must</strong> be a Vulkan object of the type associated with <code>objectType</code> as defined in &amp;lt;&amp;lt;debugging-object-types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-objectType-parameter",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkObjectType\">VkObjectType</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-pTag-parameter",\r
+ "text": " <code>pTag</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>tagSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsObjectTagInfoEXT-tagSize-arraylength",\r
+ "text": " <code>tagSize</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkQueueBeginDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkQueueBeginDebugUtilsLabelEXT-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueBeginDebugUtilsLabelEXT-pLabelInfo-parameter",\r
+ "text": " <code>pLabelInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsLabelEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsLabelEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsLabelEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsLabelEXT-pLabelName-parameter",\r
+ "text": " <code>pLabelName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkQueueEndDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkQueueEndDebugUtilsLabelEXT-None-01911",\r
+ "text": " There <strong class=\"purple\">must</strong> be an outstanding <code>vkQueueBeginDebugUtilsLabelEXT</code> command prior to the <code>vkQueueEndDebugUtilsLabelEXT</code> on the queue"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueEndDebugUtilsLabelEXT-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "vkQueueInsertDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkQueueInsertDebugUtilsLabelEXT-queue-parameter",\r
+ "text": " <code>queue</code> <strong class=\"purple\">must</strong> be a valid <code>VkQueue</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkQueueInsertDebugUtilsLabelEXT-pLabelInfo-parameter",\r
+ "text": " <code>pLabelInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsLabelEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdBeginDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkCmdBeginDebugUtilsLabelEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginDebugUtilsLabelEXT-pLabelInfo-parameter",\r
+ "text": " <code>pLabelInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsLabelEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginDebugUtilsLabelEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdBeginDebugUtilsLabelEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdEndDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkCmdEndDebugUtilsLabelEXT-commandBuffer-01912",\r
+ "text": " There <strong class=\"purple\">must</strong> be an outstanding <code>vkCmdBeginDebugUtilsLabelEXT</code> command prior to the <code>vkCmdEndDebugUtilsLabelEXT</code> on the queue that <code>commandBuffer</code> is submitted to"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndDebugUtilsLabelEXT-commandBuffer-01913",\r
+ "text": " If <code>commandBuffer</code> is a secondary command buffer, there <strong class=\"purple\">must</strong> be an outstanding <code>vkCmdBeginDebugUtilsLabelEXT</code> command recorded to <code>commandBuffer</code> that has not previously been ended by a call to <code>vkCmdEndDebugUtilsLabelEXT</code>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndDebugUtilsLabelEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndDebugUtilsLabelEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdEndDebugUtilsLabelEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdInsertDebugUtilsLabelEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkCmdInsertDebugUtilsLabelEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdInsertDebugUtilsLabelEXT-pLabelInfo-parameter",\r
+ "text": " <code>pLabelInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsLabelEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdInsertDebugUtilsLabelEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdInsertDebugUtilsLabelEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDebugUtilsMessengerEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkCreateDebugUtilsMessengerEXT-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDebugUtilsMessengerEXT-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsMessengerCreateInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDebugUtilsMessengerEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDebugUtilsMessengerEXT-pMessenger-parameter",\r
+ "text": " <code>pMessenger</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDebugUtilsMessengerEXT</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugUtilsMessengerCreateInfoEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-pfnUserCallback-01914",\r
+ "text": " <code>pfnUserCallback</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#PFN_vkDebugUtilsMessengerCallbackEXT\">PFN_vkDebugUtilsMessengerCallbackEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-messageSeverity-parameter",\r
+ "text": " <code>messageSeverity</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDebugUtilsMessageSeverityFlagBitsEXT\">VkDebugUtilsMessageSeverityFlagBitsEXT</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-messageSeverity-requiredbitmask",\r
+ "text": " <code>messageSeverity</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-messageType-parameter",\r
+ "text": " <code>messageType</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDebugUtilsMessageTypeFlagBitsEXT\">VkDebugUtilsMessageTypeFlagBitsEXT</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCreateInfoEXT-messageType-requiredbitmask",\r
+ "text": " <code>messageType</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugUtilsMessengerCallbackDataEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCallbackDataEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCallbackDataEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCallbackDataEXT-flags-zerobitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCallbackDataEXT-pMessageIdName-parameter",\r
+ "text": " If <code>pMessageIdName</code> is not <code>NULL</code>, <code>pMessageIdName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCallbackDataEXT-pMessage-parameter",\r
+ "text": " <code>pMessage</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugUtilsMessengerCallbackDataEXT-objectCount-arraylength",\r
+ "text": " <code>objectCount</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkSubmitDebugUtilsMessageEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkSubmitDebugUtilsMessageEXT-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSubmitDebugUtilsMessageEXT-messageSeverity-parameter",\r
+ "text": " <code>messageSeverity</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDebugUtilsMessageSeverityFlagBitsEXT\">VkDebugUtilsMessageSeverityFlagBitsEXT</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSubmitDebugUtilsMessageEXT-messageTypes-parameter",\r
+ "text": " <code>messageTypes</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDebugUtilsMessageTypeFlagBitsEXT\">VkDebugUtilsMessageTypeFlagBitsEXT</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSubmitDebugUtilsMessageEXT-messageTypes-requiredbitmask",\r
+ "text": " <code>messageTypes</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkSubmitDebugUtilsMessageEXT-pCallbackData-parameter",\r
+ "text": " <code>pCallbackData</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugUtilsMessengerCallbackDataEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyDebugUtilsMessengerEXT": {\r
+ "(VK_EXT_debug_utils)": [\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugUtilsMessengerEXT-messenger-01915",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>messenger</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugUtilsMessengerEXT-messenger-01916",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>messenger</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugUtilsMessengerEXT-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugUtilsMessengerEXT-messenger-parameter",\r
+ "text": " <code>messenger</code> <strong class=\"purple\">must</strong> be a valid <code>VkDebugUtilsMessengerEXT</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugUtilsMessengerEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugUtilsMessengerEXT-messenger-parent",\r
+ "text": " <code>messenger</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>instance</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkDebugMarkerSetObjectNameEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-vkDebugMarkerSetObjectNameEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugMarkerSetObjectNameEXT-pNameInfo-parameter",\r
+ "text": " <code>pNameInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugMarkerObjectNameInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugMarkerObjectNameInfoEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-objectType-01490",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> not be <code>VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-object-01491",\r
+ "text": " <code>object</code> <strong class=\"purple\">must</strong> not be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-object-01492",\r
+ "text": " <code>object</code> <strong class=\"purple\">must</strong> be a Vulkan object of the type associated with <code>objectType</code> as defined in &amp;lt;&amp;lt;debug-report-object-types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-objectType-parameter",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDebugReportObjectTypeEXT\">VkDebugReportObjectTypeEXT</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectNameInfoEXT-pObjectName-parameter",\r
+ "text": " <code>pObjectName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkDebugMarkerSetObjectTagEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-vkDebugMarkerSetObjectTagEXT-device-parameter",\r
+ "text": " <code>device</code> <strong class=\"purple\">must</strong> be a valid <code>VkDevice</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugMarkerSetObjectTagEXT-pTagInfo-parameter",\r
+ "text": " <code>pTagInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugMarkerObjectTagInfoEXT</code> structure"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugMarkerObjectTagInfoEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-objectType-01493",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> not be <code>VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-object-01494",\r
+ "text": " <code>object</code> <strong class=\"purple\">must</strong> not be <a href=\"#VK_NULL_HANDLE\">VK_NULL_HANDLE</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-object-01495",\r
+ "text": " <code>object</code> <strong class=\"purple\">must</strong> be a Vulkan object of the type associated with <code>objectType</code> as defined in &amp;lt;&amp;lt;debug-report-object-types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-objectType-parameter",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDebugReportObjectTypeEXT\">VkDebugReportObjectTypeEXT</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-pTag-parameter",\r
+ "text": " <code>pTag</code> <strong class=\"purple\">must</strong> be a valid pointer to an array of <code>tagSize</code> bytes"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerObjectTagInfoEXT-tagSize-arraylength",\r
+ "text": " <code>tagSize</code> <strong class=\"purple\">must</strong> be greater than <code>0</code>"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDebugMarkerBeginEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerBeginEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerBeginEXT-pMarkerInfo-parameter",\r
+ "text": " <code>pMarkerInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugMarkerMarkerInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerBeginEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerBeginEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugMarkerMarkerInfoEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerMarkerInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerMarkerInfoEXT-pNext-pNext",\r
+ "text": " <code>pNext</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugMarkerMarkerInfoEXT-pMarkerName-parameter",\r
+ "text": " <code>pMarkerName</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDebugMarkerEndEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerEndEXT-commandBuffer-01239",\r
+ "text": " There <strong class=\"purple\">must</strong> be an outstanding <a href=\"#vkCmdDebugMarkerBeginEXT\">vkCmdDebugMarkerBeginEXT</a> command prior to the <code>vkCmdDebugMarkerEndEXT</code> on the queue that <code>commandBuffer</code> is submitted to"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerEndEXT-commandBuffer-01240",\r
+ "text": " If <code>commandBuffer</code> is a secondary command buffer, there <strong class=\"purple\">must</strong> be an outstanding <a href=\"#vkCmdDebugMarkerBeginEXT\">vkCmdDebugMarkerBeginEXT</a> command recorded to <code>commandBuffer</code> that has not previously been ended by a call to <a href=\"#vkCmdDebugMarkerEndEXT\">vkCmdDebugMarkerEndEXT</a>."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerEndEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerEndEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerEndEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCmdDebugMarkerInsertEXT": {\r
+ "(VK_EXT_debug_marker)": [\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerInsertEXT-commandBuffer-parameter",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be a valid <code>VkCommandBuffer</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerInsertEXT-pMarkerInfo-parameter",\r
+ "text": " <code>pMarkerInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugMarkerMarkerInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerInsertEXT-commandBuffer-recording",\r
+ "text": " <code>commandBuffer</code> <strong class=\"purple\">must</strong> be in the &amp;lt;&amp;lt;commandbuffers-lifecycle, recording state&amp;gt;&amp;gt;"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCmdDebugMarkerInsertEXT-commandBuffer-cmdpool",\r
+ "text": " The <code>VkCommandPool</code> that <code>commandBuffer</code> was allocated from <strong class=\"purple\">must</strong> support graphics, or compute operations"\r
+ }\r
+ ]\r
+ },\r
+ "vkCreateDebugReportCallbackEXT": {\r
+ "(VK_EXT_debug_report)": [\r
+ {\r
+ "vuid": "VUID-vkCreateDebugReportCallbackEXT-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDebugReportCallbackEXT-pCreateInfo-parameter",\r
+ "text": " <code>pCreateInfo</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkDebugReportCallbackCreateInfoEXT</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDebugReportCallbackEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkCreateDebugReportCallbackEXT-pCallback-parameter",\r
+ "text": " <code>pCallback</code> <strong class=\"purple\">must</strong> be a valid pointer to a <code>VkDebugReportCallbackEXT</code> handle"\r
+ }\r
+ ]\r
+ },\r
+ "VkDebugReportCallbackCreateInfoEXT": {\r
+ "(VK_EXT_debug_report)": [\r
+ {\r
+ "vuid": "VUID-VkDebugReportCallbackCreateInfoEXT-pfnCallback-01385",\r
+ "text": " <code>pfnCallback</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#PFN_vkDebugReportCallbackEXT\">PFN_vkDebugReportCallbackEXT</a>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugReportCallbackCreateInfoEXT-sType-sType",\r
+ "text": " <code>sType</code> <strong class=\"purple\">must</strong> be <code>VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-VkDebugReportCallbackCreateInfoEXT-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDebugReportFlagBitsEXT\">VkDebugReportFlagBitsEXT</a> values"\r
+ }\r
+ ]\r
+ },\r
+ "vkDebugReportMessageEXT": {\r
+ "(VK_EXT_debug_report)": [\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-object-01241",\r
+ "text": " <code>object</code> <strong class=\"purple\">must</strong> be a Vulkan object or <code>VK_NULL_HANDLE</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-objectType-01498",\r
+ "text": " If <code>objectType</code> is not <code>VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT</code> and <code>object</code> is not <code>VK_NULL_HANDLE</code>, <code>object</code> <strong class=\"purple\">must</strong> be a Vulkan object of the corresponding type associated with <code>objectType</code> as defined in &amp;lt;&amp;lt;debug-report-object-types&amp;gt;&amp;gt;."\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-flags-parameter",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> be a valid combination of <a href=\"#VkDebugReportFlagBitsEXT\">VkDebugReportFlagBitsEXT</a> values"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-flags-requiredbitmask",\r
+ "text": " <code>flags</code> <strong class=\"purple\">must</strong> not be <code>0</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-objectType-parameter",\r
+ "text": " <code>objectType</code> <strong class=\"purple\">must</strong> be a valid <a href=\"#VkDebugReportObjectTypeEXT\">VkDebugReportObjectTypeEXT</a> value"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-pLayerPrefix-parameter",\r
+ "text": " <code>pLayerPrefix</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDebugReportMessageEXT-pMessage-parameter",\r
+ "text": " <code>pMessage</code> <strong class=\"purple\">must</strong> be a null-terminated UTF-8 string"\r
+ }\r
+ ]\r
+ },\r
+ "vkDestroyDebugReportCallbackEXT": {\r
+ "(VK_EXT_debug_report)": [\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugReportCallbackEXT-instance-01242",\r
+ "text": " If <code>VkAllocationCallbacks</code> were provided when <code>callback</code> was created, a compatible set of callbacks <strong class=\"purple\">must</strong> be provided here"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugReportCallbackEXT-instance-01243",\r
+ "text": " If no <code>VkAllocationCallbacks</code> were provided when <code>callback</code> was created, <code>pAllocator</code> <strong class=\"purple\">must</strong> be <code>NULL</code>"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugReportCallbackEXT-instance-parameter",\r
+ "text": " <code>instance</code> <strong class=\"purple\">must</strong> be a valid <code>VkInstance</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugReportCallbackEXT-callback-parameter",\r
+ "text": " <code>callback</code> <strong class=\"purple\">must</strong> be a valid <code>VkDebugReportCallbackEXT</code> handle"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugReportCallbackEXT-pAllocator-parameter",\r
+ "text": " If <code>pAllocator</code> is not <code>NULL</code>, <code>pAllocator</code> <strong class=\"purple\">must</strong> be a valid pointer to a valid <code>VkAllocationCallbacks</code> structure"\r
+ },\r
+ {\r
+ "vuid": "VUID-vkDestroyDebugReportCallbackEXT-callback-parent",\r
+ "text": " <code>callback</code> <strong class=\"purple\">must</strong> have been created, allocated, or retrieved from <code>instance</code>"\r
+ }\r
+ ]\r
+ }\r
+ }\r
+}
\ No newline at end of file
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<registry>
+ <comment>
+Copyright (c) 2015-2018 The Khronos Group 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.
+
+------------------------------------------------------------------------
+
+This file, vk.xml, is the Vulkan API Registry. It is a critically important
+and normative part of the Vulkan Specification, including a canonical
+machine-readable definition of the API, parameter and member validation
+language incorporated into the Specification and reference pages, and other
+material which is registered by Khronos, such as tags used by extension and
+layer authors. The authoritative public version of vk.xml is maintained in
+the master branch of the Khronos Vulkan GitHub project. The authoritative
+private version is maintained in the master branch of the member gitlab
+server.
+ </comment>
+
+ <vendorids comment="Vulkan vendor IDs for physical devices without PCI vendor IDs">
+ <vendorid name="KHR" id="0x10000" comment="This is the next available Khronos vendor ID"/>
+ <vendorid name="VIV" id="0x10001" comment="Vivante vendor ID"/>
+ <vendorid name="VSI" id="0x10002" comment="VeriSilicon vendor ID"/>
+ <vendorid name="KAZAN" id="0x10003" comment="Kazan Software Renderer"/>
+ </vendorids>
+
+ <platforms comment="Vulkan platform names, reserved for use with platform- and window system-specific extensions">
+ <platform name="xlib" protect="VK_USE_PLATFORM_XLIB_KHR" comment="X Window System, Xlib client library"/>
+ <platform name="xlib_xrandr" protect="VK_USE_PLATFORM_XLIB_XRANDR_EXT" comment="X Window System, Xlib client library, XRandR extension"/>
+ <platform name="xcb" protect="VK_USE_PLATFORM_XCB_KHR" comment="X Window System, Xcb client library"/>
+ <platform name="wayland" protect="VK_USE_PLATFORM_WAYLAND_KHR" comment="Wayland display server protocol"/>
+ <platform name="mir" protect="VK_USE_PLATFORM_MIR_KHR" comment="Mir display server"/>
+ <platform name="android" protect="VK_USE_PLATFORM_ANDROID_KHR" comment="Android OS"/>
+ <platform name="win32" protect="VK_USE_PLATFORM_WIN32_KHR" comment="Microsoft Win32 API (also refers to Win64 apps)"/>
+ <platform name="vi" protect="VK_USE_PLATFORM_VI_NN" comment="Nintendo Vi"/>
+ <platform name="ios" protect="VK_USE_PLATFORM_IOS_MVK" comment="Apple IOS"/>
+ <platform name="macos" protect="VK_USE_PLATFORM_MACOS_MVK" comment="Apple MacOS"/>
+ </platforms>
+
+ <tags comment="Vulkan vendor/author tags for extensions and layers">
+ <tag name="IMG" author="Imagination Technologies" contact="Michael Worcester @michaelworcester"/>
+ <tag name="AMD" author="Advanced Micro Devices, Inc." contact="Daniel Rakos @aqnuep"/>
+ <tag name="AMDX" author="Advanced Micro Devices, Inc." contact="Daniel Rakos @aqnuep"/>
+ <tag name="ARM" author="ARM Limited" contact="Jan-Harald Fredriksen @janharald"/>
+ <tag name="FSL" author="Freescale Semiconductor, Inc." contact="Norbert Nopper @FslNopper"/>
+ <tag name="BRCM" author="Broadcom Corporation" contact="Graeme Leese @gnl21"/>
+ <tag name="NXP" author="NXP Semiconductors N.V." contact="Norbert Nopper @FslNopper"/>
+ <tag name="NV" author="NVIDIA Corporation" contact="Daniel Koch @dgkoch"/>
+ <tag name="NVX" author="NVIDIA Corporation" contact="Daniel Koch @dgkoch"/>
+ <tag name="VIV" author="Vivante Corporation" contact="Yanjun Zhang @yanjunzhang"/>
+ <tag name="VSI" author="VeriSilicon Holdings Co., Ltd." contact="Yanjun Zhang @yanjunzhang"/>
+ <tag name="KDAB" author="KDAB" contact="Sean Harmer @seanharmer"/>
+ <tag name="ANDROID" author="Google, Inc." contact="Jesse Hall @jessehall"/>
+ <tag name="CHROMIUM" author="Google, Inc." contact="Jesse Hall @jessehall"/>
+ <tag name="GOOGLE" author="Google, Inc." contact="Jesse Hall @jessehall"/>
+ <tag name="QCOM" author="Qualcomm Technologies, Inc." contact="Maurice Ribble @mribble"/>
+ <tag name="LUNARG" author="LunarG, Inc." contact="Karen Ghavam @KarenGhavam"/>
+ <tag name="SAMSUNG" author="Samsung Electronics Co., Ltd." contact="Alon Or-bach @alonorbach"/>
+ <tag name="SEC" author="Samsung Electronics Co., Ltd." contact="Alon Or-bach @alonorbach"/>
+ <tag name="TIZEN" author="Samsung Electronics Co., Ltd." contact="Alon Or-bach @alonorbach"/>
+ <tag name="RENDERDOC" author="RenderDoc (renderdoc.org)" contact="baldurk@baldurk.org"/>
+ <tag name="NN" author="Nintendo Co., Ltd." contact="Yasuhiro Yoshioka @yoshioka_yasuhiro"/>
+ <tag name="MVK" author="The Brenwill Workshop Ltd." contact="Bill Hollings @billhollings"/>
+ <tag name="KHR" author="Khronos" contact="Tom Olson @tom.olson"/>
+ <tag name="KHX" author="Khronos" contact="Tom Olson @tom.olson"/>
+ <tag name="EXT" author="Multivendor" contact="Jon Leech @oddhack"/>
+ <tag name="MESA" author="Mesa open source project" contact="Chad Versace @chadversary, Daniel Stone @fooishbar, David Airlie @airlied, Jason Ekstrand @jekstrand"/>
+ </tags>
+
+ <types comment="Vulkan type definitions">
+ <type name="vk_platform" category="include">#include "vk_platform.h"</type>
+
+ <comment>WSI extensions</comment>
+
+ <type category="include" name="X11/Xlib.h"/>
+ <type category="include" name="X11/extensions/Xrandr.h"/>
+ <type category="include" name="mir_toolkit/client_types.h"/>
+ <type category="include" name="wayland-client.h"/>
+ <type category="include" name="windows.h"/>
+ <type category="include" name="xcb/xcb.h"/>
+ <comment>
+ In the current header structure, each platform's interfaces
+ are confined to a platform-specific header (vulkan_xlib.h,
+ vulkan_win32.h, etc.). These headers are not self-contained,
+ and should not include native headers (X11/Xlib.h,
+ windows.h, etc.). Code should either include vulkan.h after
+ defining the appropriate VK_USE_PLATFORM_platform_KHR
+ macros, or include the required native headers prior to
+ explicitly including the corresponding platform header.
+
+ To accomplish this, the dependencies of native types require
+ native headers, but the XML defines the content for those
+ native headers as empty. The actual native header includes
+ can be restored by modifying the native header tags above
+ to #include the header file in the 'name' attribute.
+ </comment>
+
+ <type requires="X11/Xlib.h" name="Display"/>
+ <type requires="X11/Xlib.h" name="VisualID"/>
+ <type requires="X11/Xlib.h" name="Window"/>
+ <type requires="X11/extensions/Xrandr.h" name="RROutput"/>
+ <type requires="mir_toolkit/client_types.h" name="MirConnection"/>
+ <type requires="mir_toolkit/client_types.h" name="MirSurface"/>
+ <type requires="wayland-client.h" name="wl_display"/>
+ <type requires="wayland-client.h" name="wl_surface"/>
+ <type requires="windows.h" name="HINSTANCE"/>
+ <type requires="windows.h" name="HWND"/>
+ <type requires="windows.h" name="HANDLE"/>
+ <type requires="windows.h" name="SECURITY_ATTRIBUTES"/>
+ <type requires="windows.h" name="DWORD"/>
+ <type requires="windows.h" name="LPCWSTR"/>
+ <type requires="xcb/xcb.h" name="xcb_connection_t"/>
+ <type requires="xcb/xcb.h" name="xcb_visualid_t"/>
+ <type requires="xcb/xcb.h" name="xcb_window_t"/>
+
+ <type category="define">#define <name>VK_MAKE_VERSION</name>(major, minor, patch) \
+ (((major) << 22) | ((minor) << 12) | (patch))</type>
+ <type category="define">#define <name>VK_VERSION_MAJOR</name>(version) ((uint32_t)(version) >> 22)</type>
+ <type category="define">#define <name>VK_VERSION_MINOR</name>(version) (((uint32_t)(version) >> 12) & 0x3ff)</type>
+ <type category="define">#define <name>VK_VERSION_PATCH</name>(version) ((uint32_t)(version) & 0xfff)</type>
+
+ <type category="define">// DEPRECATED: This define has been removed. Specific version defines (e.g. VK_API_VERSION_1_0), or the VK_MAKE_VERSION macro, should be used instead.
+//#define <name>VK_API_VERSION</name> <type>VK_MAKE_VERSION</type>(1, 0, 0) // Patch version should always be set to 0</type>
+ <type category="define">// Vulkan 1.0 version number
+#define <name>VK_API_VERSION_1_0</name> <type>VK_MAKE_VERSION</type>(1, 0, 0)// Patch version should always be set to 0</type>
+ <type category="define">// Vulkan 1.1 version number
+#define <name>VK_API_VERSION_1_1</name> <type>VK_MAKE_VERSION</type>(1, 1, 0)// Patch version should always be set to 0</type>
+ <type category="define">// Version of this file
+#define <name>VK_HEADER_VERSION</name> 74</type>
+
+ <type category="define">
+#define <name>VK_DEFINE_HANDLE</name>(object) typedef struct object##_T* object;</type>
+
+ <type category="define" name="VK_DEFINE_NON_DISPATCHABLE_HANDLE">
+#if !defined(VK_DEFINE_NON_DISPATCHABLE_HANDLE)
+#if defined(__LP64__) || defined(_WIN64) || (defined(__x86_64__) && !defined(__ILP32__) ) || defined(_M_X64) || defined(__ia64) || defined (_M_IA64) || defined(__aarch64__) || defined(__powerpc64__)
+ #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef struct object##_T *object;
+#else
+ #define VK_DEFINE_NON_DISPATCHABLE_HANDLE(object) typedef uint64_t object;
+#endif
+#endif
+ </type>
+
+ <type category="define">
+#define <name>VK_NULL_HANDLE</name> 0
+ </type>
+
+ <type category="define">struct <name>ANativeWindow</name>;</type>
+ <type category="define">struct <name>AHardwareBuffer</name>;</type>
+
+ <type category="basetype">typedef <type>uint32_t</type> <name>VkSampleMask</name>;</type>
+ <type category="basetype">typedef <type>uint32_t</type> <name>VkBool32</name>;</type>
+ <type category="basetype">typedef <type>uint32_t</type> <name>VkFlags</name>;</type>
+ <type category="basetype">typedef <type>uint64_t</type> <name>VkDeviceSize</name>;</type>
+
+ <comment>Basic C types, pulled in via vk_platform.h</comment>
+ <type requires="vk_platform" name="void"/>
+ <type requires="vk_platform" name="char"/>
+ <type requires="vk_platform" name="float"/>
+ <type requires="vk_platform" name="uint8_t"/>
+ <type requires="vk_platform" name="uint32_t"/>
+ <type requires="vk_platform" name="uint64_t"/>
+ <type requires="vk_platform" name="int32_t"/>
+ <type requires="vk_platform" name="size_t"/>
+ <type name="int"/>
+
+ <comment>Bitmask types</comment>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkFramebufferCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkQueryPoolCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkRenderPassCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkSamplerCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineLayoutCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineCacheCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineDepthStencilStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineDynamicStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineColorBlendStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineMultisampleStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineRasterizationStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineViewportStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineTessellationStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineInputAssemblyStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineVertexInputStateCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineShaderStageCreateFlags</name>;</type>
+ <type requires="VkDescriptorSetLayoutCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkDescriptorSetLayoutCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkBufferViewCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkInstanceCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDeviceCreateFlags</name>;</type>
+ <type requires="VkDeviceQueueCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkDeviceQueueCreateFlags</name>;</type>
+ <type requires="VkQueueFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkQueueFlags</name>;</type>
+ <type requires="VkMemoryPropertyFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkMemoryPropertyFlags</name>;</type>
+ <type requires="VkMemoryHeapFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkMemoryHeapFlags</name>;</type>
+ <type requires="VkAccessFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkAccessFlags</name>;</type>
+ <type requires="VkBufferUsageFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkBufferUsageFlags</name>;</type>
+ <type requires="VkBufferCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkBufferCreateFlags</name>;</type>
+ <type requires="VkShaderStageFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkShaderStageFlags</name>;</type>
+ <type requires="VkImageUsageFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkImageUsageFlags</name>;</type>
+ <type requires="VkImageCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkImageCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkImageViewCreateFlags</name>;</type>
+ <type requires="VkPipelineCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineCreateFlags</name>;</type>
+ <type requires="VkColorComponentFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkColorComponentFlags</name>;</type>
+ <type requires="VkFenceCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkFenceCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkSemaphoreCreateFlags</name>;</type>
+ <type requires="VkFormatFeatureFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkFormatFeatureFlags</name>;</type>
+ <type requires="VkQueryControlFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkQueryControlFlags</name>;</type>
+ <type requires="VkQueryResultFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkQueryResultFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkShaderModuleCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkEventCreateFlags</name>;</type>
+ <type requires="VkCommandPoolCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkCommandPoolCreateFlags</name>;</type>
+ <type requires="VkCommandPoolResetFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkCommandPoolResetFlags</name>;</type>
+ <type requires="VkCommandBufferResetFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkCommandBufferResetFlags</name>;</type>
+ <type requires="VkCommandBufferUsageFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkCommandBufferUsageFlags</name>;</type>
+ <type requires="VkQueryPipelineStatisticFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkQueryPipelineStatisticFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkMemoryMapFlags</name>;</type>
+ <type requires="VkImageAspectFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkImageAspectFlags</name>;</type>
+ <type requires="VkSparseMemoryBindFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkSparseMemoryBindFlags</name>;</type>
+ <type requires="VkSparseImageFormatFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkSparseImageFormatFlags</name>;</type>
+ <type requires="VkSubpassDescriptionFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkSubpassDescriptionFlags</name>;</type>
+ <type requires="VkPipelineStageFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineStageFlags</name>;</type>
+ <type requires="VkSampleCountFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkSampleCountFlags</name>;</type>
+ <type requires="VkAttachmentDescriptionFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkAttachmentDescriptionFlags</name>;</type>
+ <type requires="VkStencilFaceFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkStencilFaceFlags</name>;</type>
+ <type requires="VkCullModeFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkCullModeFlags</name>;</type>
+ <type requires="VkDescriptorPoolCreateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkDescriptorPoolCreateFlags</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDescriptorPoolResetFlags</name>;</type>
+ <type requires="VkDependencyFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkDependencyFlags</name>;</type>
+ <type requires="VkSubgroupFeatureFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkSubgroupFeatureFlags</name>;</type>
+ <type requires="VkIndirectCommandsLayoutUsageFlagBitsNVX" category="bitmask">typedef <type>VkFlags</type> <name>VkIndirectCommandsLayoutUsageFlagsNVX</name>;</type>
+ <type requires="VkObjectEntryUsageFlagBitsNVX" category="bitmask">typedef <type>VkFlags</type> <name>VkObjectEntryUsageFlagsNVX</name>;</type>
+
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDescriptorUpdateTemplateCreateFlags</name>;</type>
+ <type category="bitmask" name="VkDescriptorUpdateTemplateCreateFlagsKHR" alias="VkDescriptorUpdateTemplateCreateFlags"/>
+
+ <comment>WSI extensions</comment>
+ <type requires="VkCompositeAlphaFlagBitsKHR" category="bitmask">typedef <type>VkFlags</type> <name>VkCompositeAlphaFlagsKHR</name>;</type>
+ <type requires="VkDisplayPlaneAlphaFlagBitsKHR" category="bitmask">typedef <type>VkFlags</type> <name>VkDisplayPlaneAlphaFlagsKHR</name>;</type>
+ <type requires="VkSurfaceTransformFlagBitsKHR" category="bitmask">typedef <type>VkFlags</type> <name>VkSurfaceTransformFlagsKHR</name>;</type>
+ <type requires="VkSwapchainCreateFlagBitsKHR" category="bitmask">typedef <type>VkFlags</type> <name>VkSwapchainCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDisplayModeCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDisplaySurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkAndroidSurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkMirSurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkViSurfaceCreateFlagsNN</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkWaylandSurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkWin32SurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkXlibSurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkXcbSurfaceCreateFlagsKHR</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkIOSSurfaceCreateFlagsMVK</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkMacOSSurfaceCreateFlagsMVK</name>;</type>
+ <type requires="VkPeerMemoryFeatureFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkPeerMemoryFeatureFlags</name>;</type>
+ <type category="bitmask" name="VkPeerMemoryFeatureFlagsKHR" alias="VkPeerMemoryFeatureFlags"/>
+ <type requires="VkMemoryAllocateFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkMemoryAllocateFlags</name>;</type>
+ <type category="bitmask" name="VkMemoryAllocateFlagsKHR" alias="VkMemoryAllocateFlags"/>
+ <type requires="VkDeviceGroupPresentModeFlagBitsKHR" category="bitmask">typedef <type>VkFlags</type> <name>VkDeviceGroupPresentModeFlagsKHR</name>;</type>
+
+ <type requires="VkDebugReportFlagBitsEXT" category="bitmask">typedef <type>VkFlags</type> <name>VkDebugReportFlagsEXT</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkCommandPoolTrimFlags</name>;</type>
+ <type category="bitmask" name="VkCommandPoolTrimFlagsKHR" alias="VkCommandPoolTrimFlags"/>
+ <type requires="VkExternalMemoryHandleTypeFlagBitsNV" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalMemoryHandleTypeFlagsNV</name>;</type>
+ <type requires="VkExternalMemoryFeatureFlagBitsNV" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalMemoryFeatureFlagsNV</name>;</type>
+ <type requires="VkExternalMemoryHandleTypeFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalMemoryHandleTypeFlags</name>;</type>
+ <type category="bitmask" name="VkExternalMemoryHandleTypeFlagsKHR" alias="VkExternalMemoryHandleTypeFlags"/>
+ <type requires="VkExternalMemoryFeatureFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalMemoryFeatureFlags</name>;</type>
+ <type category="bitmask" name="VkExternalMemoryFeatureFlagsKHR" alias="VkExternalMemoryFeatureFlags"/>
+ <type requires="VkExternalSemaphoreHandleTypeFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalSemaphoreHandleTypeFlags</name>;</type>
+ <type category="bitmask" name="VkExternalSemaphoreHandleTypeFlagsKHR" alias="VkExternalSemaphoreHandleTypeFlags"/>
+ <type requires="VkExternalSemaphoreFeatureFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalSemaphoreFeatureFlags</name>;</type>
+ <type category="bitmask" name="VkExternalSemaphoreFeatureFlagsKHR" alias="VkExternalSemaphoreFeatureFlags"/>
+ <type requires="VkSemaphoreImportFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkSemaphoreImportFlags</name>;</type>
+ <type category="bitmask" name="VkSemaphoreImportFlagsKHR" alias="VkSemaphoreImportFlags"/>
+ <type requires="VkExternalFenceHandleTypeFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalFenceHandleTypeFlags</name>;</type>
+ <type category="bitmask" name="VkExternalFenceHandleTypeFlagsKHR" alias="VkExternalFenceHandleTypeFlags"/>
+ <type requires="VkExternalFenceFeatureFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkExternalFenceFeatureFlags</name>;</type>
+ <type category="bitmask" name="VkExternalFenceFeatureFlagsKHR" alias="VkExternalFenceFeatureFlags"/>
+ <type requires="VkFenceImportFlagBits" category="bitmask">typedef <type>VkFlags</type> <name>VkFenceImportFlags</name>;</type>
+ <type category="bitmask" name="VkFenceImportFlagsKHR" alias="VkFenceImportFlags"/>
+ <type requires="VkSurfaceCounterFlagBitsEXT" category="bitmask">typedef <type>VkFlags</type> <name>VkSurfaceCounterFlagsEXT</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineViewportSwizzleStateCreateFlagsNV</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineDiscardRectangleStateCreateFlagsEXT</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineCoverageToColorStateCreateFlagsNV</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineCoverageModulationStateCreateFlagsNV</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkValidationCacheCreateFlagsEXT</name>;</type>
+ <type requires="VkDebugUtilsMessageSeverityFlagBitsEXT" category="bitmask">typedef <type>VkFlags</type> <name>VkDebugUtilsMessageSeverityFlagsEXT</name>;</type>
+ <type requires="VkDebugUtilsMessageTypeFlagBitsEXT" category="bitmask">typedef <type>VkFlags</type> <name>VkDebugUtilsMessageTypeFlagsEXT</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDebugUtilsMessengerCreateFlagsEXT</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkDebugUtilsMessengerCallbackDataFlagsEXT</name>;</type>
+ <type category="bitmask">typedef <type>VkFlags</type> <name>VkPipelineRasterizationConservativeStateCreateFlagsEXT</name>;</type>
+ <type requires="VkDescriptorBindingFlagBitsEXT" category="bitmask">typedef <type>VkFlags</type> <name>VkDescriptorBindingFlagsEXT</name>;</type>
+
+ <comment>Types which can be void pointers or class pointers, selected at compile time</comment>
+ <type category="handle"><type>VK_DEFINE_HANDLE</type>(<name>VkInstance</name>)</type>
+ <type category="handle" parent="VkInstance"><type>VK_DEFINE_HANDLE</type>(<name>VkPhysicalDevice</name>)</type>
+ <type category="handle" parent="VkPhysicalDevice"><type>VK_DEFINE_HANDLE</type>(<name>VkDevice</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_HANDLE</type>(<name>VkQueue</name>)</type>
+ <type category="handle" parent="VkCommandPool"><type>VK_DEFINE_HANDLE</type>(<name>VkCommandBuffer</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDeviceMemory</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkCommandPool</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkBuffer</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkBufferView</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkImage</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkImageView</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkShaderModule</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkPipeline</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkPipelineLayout</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkSampler</name>)</type>
+ <type category="handle" parent="VkDescriptorPool"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDescriptorSet</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDescriptorSetLayout</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDescriptorPool</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkFence</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkSemaphore</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkEvent</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkQueryPool</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkFramebuffer</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkRenderPass</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkPipelineCache</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkObjectTableNVX</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkIndirectCommandsLayoutNVX</name>)</type>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDescriptorUpdateTemplate</name>)</type>
+ <type category="handle" name="VkDescriptorUpdateTemplateKHR" alias="VkDescriptorUpdateTemplate"/>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkSamplerYcbcrConversion</name>)</type>
+ <type category="handle" name="VkSamplerYcbcrConversionKHR" alias="VkSamplerYcbcrConversion"/>
+ <type category="handle" parent="VkDevice"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkValidationCacheEXT</name>)</type>
+
+ <comment>WSI extensions</comment>
+ <type category="handle"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDisplayKHR</name>)</type>
+ <type category="handle" parent="VkPhysicalDevice,VkDisplayKHR"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDisplayModeKHR</name>)</type>
+ <type category="handle" parent="VkInstance"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkSurfaceKHR</name>)</type>
+ <type category="handle" parent="VkSurfaceKHR"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkSwapchainKHR</name>)</type>
+ <type category="handle" parent="VkInstance"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDebugReportCallbackEXT</name>)</type>
+ <type category="handle" parent="VkInstance"><type>VK_DEFINE_NON_DISPATCHABLE_HANDLE</type>(<name>VkDebugUtilsMessengerEXT</name>)</type>
+
+ <comment>Types generated from corresponding enums tags below</comment>
+ <type name="VkAttachmentLoadOp" category="enum"/>
+ <type name="VkAttachmentStoreOp" category="enum"/>
+ <type name="VkBlendFactor" category="enum"/>
+ <type name="VkBlendOp" category="enum"/>
+ <type name="VkBorderColor" category="enum"/>
+ <type name="VkFramebufferCreateFlagBits" category="enum"/>
+ <type name="VkQueryPoolCreateFlagBits" category="enum"/>
+ <type name="VkRenderPassCreateFlagBits" category="enum"/>
+ <type name="VkSamplerCreateFlagBits" category="enum"/>
+ <type name="VkPipelineCacheHeaderVersion" category="enum"/>
+ <type name="VkPipelineLayoutCreateFlagBits" category="enum"/>
+ <type name="VkPipelineCacheCreateFlagBits" category="enum"/>
+ <type name="VkPipelineDepthStencilStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineDynamicStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineColorBlendStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineMultisampleStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineRasterizationStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineViewportStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineTessellationStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineInputAssemblyStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineVertexInputStateCreateFlagBits" category="enum"/>
+ <type name="VkPipelineShaderStageCreateFlagBits" category="enum"/>
+ <type name="VkDescriptorSetLayoutCreateFlagBits" category="enum"/>
+ <type name="VkBufferViewCreateFlagBits" category="enum"/>
+ <type name="VkInstanceCreateFlagBits" category="enum"/>
+ <type name="VkDeviceQueueCreateFlagBits" category="enum"/>
+ <type name="VkBufferCreateFlagBits" category="enum"/>
+ <type name="VkBufferUsageFlagBits" category="enum"/>
+ <type name="VkColorComponentFlagBits" category="enum"/>
+ <type name="VkComponentSwizzle" category="enum"/>
+ <type name="VkCommandPoolCreateFlagBits" category="enum"/>
+ <type name="VkCommandPoolResetFlagBits" category="enum"/>
+ <type name="VkCommandBufferResetFlagBits" category="enum"/>
+ <type name="VkCommandBufferLevel" category="enum"/>
+ <type name="VkCommandBufferUsageFlagBits" category="enum"/>
+ <type name="VkCompareOp" category="enum"/>
+ <type name="VkCullModeFlagBits" category="enum"/>
+ <type name="VkDescriptorType" category="enum"/>
+ <type name="VkDeviceCreateFlagBits" category="enum"/>
+ <type name="VkDynamicState" category="enum"/>
+ <type name="VkFenceCreateFlagBits" category="enum"/>
+ <type name="VkPolygonMode" category="enum"/>
+ <type name="VkFormat" category="enum"/>
+ <type name="VkFormatFeatureFlagBits" category="enum"/>
+ <type name="VkFrontFace" category="enum"/>
+ <type name="VkImageAspectFlagBits" category="enum"/>
+ <type name="VkImageCreateFlagBits" category="enum"/>
+ <type name="VkImageLayout" category="enum"/>
+ <type name="VkImageTiling" category="enum"/>
+ <type name="VkImageType" category="enum"/>
+ <type name="VkImageUsageFlagBits" category="enum"/>
+ <type name="VkImageViewType" category="enum"/>
+ <type name="VkSharingMode" category="enum"/>
+ <type name="VkIndexType" category="enum"/>
+ <type name="VkLogicOp" category="enum"/>
+ <type name="VkMemoryHeapFlagBits" category="enum"/>
+ <type name="VkAccessFlagBits" category="enum"/>
+ <type name="VkMemoryPropertyFlagBits" category="enum"/>
+ <type name="VkPhysicalDeviceType" category="enum"/>
+ <type name="VkPipelineBindPoint" category="enum"/>
+ <type name="VkPipelineCreateFlagBits" category="enum"/>
+ <type name="VkPrimitiveTopology" category="enum"/>
+ <type name="VkQueryControlFlagBits" category="enum"/>
+ <type name="VkQueryPipelineStatisticFlagBits" category="enum"/>
+ <type name="VkQueryResultFlagBits" category="enum"/>
+ <type name="VkQueryType" category="enum"/>
+ <type name="VkQueueFlagBits" category="enum"/>
+ <type name="VkSubpassContents" category="enum"/>
+ <type name="VkResult" category="enum"/>
+ <type name="VkShaderStageFlagBits" category="enum"/>
+ <type name="VkSparseMemoryBindFlagBits" category="enum"/>
+ <type name="VkStencilFaceFlagBits" category="enum"/>
+ <type name="VkStencilOp" category="enum"/>
+ <type name="VkStructureType" category="enum"/>
+ <type name="VkSystemAllocationScope" category="enum"/>
+ <type name="VkInternalAllocationType" category="enum"/>
+ <type name="VkSamplerAddressMode" category="enum"/>
+ <type name="VkFilter" category="enum"/>
+ <type name="VkSamplerMipmapMode" category="enum"/>
+ <type name="VkVertexInputRate" category="enum"/>
+ <type name="VkPipelineStageFlagBits" category="enum"/>
+ <type name="VkSparseImageFormatFlagBits" category="enum"/>
+ <type name="VkSampleCountFlagBits" category="enum"/>
+ <type name="VkAttachmentDescriptionFlagBits" category="enum"/>
+ <type name="VkDescriptorPoolCreateFlagBits" category="enum"/>
+ <type name="VkDependencyFlagBits" category="enum"/>
+ <type name="VkObjectType" category="enum"/>
+ <type name="VkDescriptorBindingFlagBitsEXT" category="enum"/>
+
+ <comment>Extensions</comment>
+ <type name="VkIndirectCommandsLayoutUsageFlagBitsNVX" category="enum"/>
+ <type name="VkIndirectCommandsTokenTypeNVX" category="enum"/>
+ <type name="VkObjectEntryUsageFlagBitsNVX" category="enum"/>
+ <type name="VkObjectEntryTypeNVX" category="enum"/>
+ <type name="VkDescriptorUpdateTemplateType" category="enum"/>
+ <type category="enum" name="VkDescriptorUpdateTemplateTypeKHR" alias="VkDescriptorUpdateTemplateType"/>
+ <type name="VkViewportCoordinateSwizzleNV" category="enum"/>
+ <type name="VkDiscardRectangleModeEXT" category="enum"/>
+ <type name="VkSubpassDescriptionFlagBits" category="enum"/>
+ <type name="VkPointClippingBehavior" category="enum"/>
+ <type category="enum" name="VkPointClippingBehaviorKHR" alias="VkPointClippingBehavior"/>
+ <type name="VkCoverageModulationModeNV" category="enum"/>
+ <type name="VkValidationCacheHeaderVersionEXT" category="enum"/>
+ <type name="VkShaderInfoTypeAMD" category="enum"/>
+ <type name="VkQueueGlobalPriorityEXT" category="enum"/>
+ <type name="VkConservativeRasterizationModeEXT" category="enum"/>
+
+ <comment>WSI extensions</comment>
+ <type name="VkColorSpaceKHR" category="enum"/>
+ <type name="VkCompositeAlphaFlagBitsKHR" category="enum"/>
+ <type name="VkDisplayPlaneAlphaFlagBitsKHR" category="enum"/>
+ <type name="VkPresentModeKHR" category="enum"/>
+ <type name="VkSurfaceTransformFlagBitsKHR" category="enum"/>
+ <type name="VkDebugReportFlagBitsEXT" category="enum"/>
+ <type name="VkDebugReportObjectTypeEXT" category="enum"/>
+ <type name="VkRasterizationOrderAMD" category="enum"/>
+ <type name="VkExternalMemoryHandleTypeFlagBitsNV" category="enum"/>
+ <type name="VkExternalMemoryFeatureFlagBitsNV" category="enum"/>
+ <type name="VkValidationCheckEXT" category="enum"/>
+ <type name="VkExternalMemoryHandleTypeFlagBits" category="enum"/>
+ <type category="enum" name="VkExternalMemoryHandleTypeFlagBitsKHR" alias="VkExternalMemoryHandleTypeFlagBits"/>
+ <type name="VkExternalMemoryFeatureFlagBits" category="enum"/>
+ <type category="enum" name="VkExternalMemoryFeatureFlagBitsKHR" alias="VkExternalMemoryFeatureFlagBits"/>
+ <type name="VkExternalSemaphoreHandleTypeFlagBits" category="enum"/>
+ <type category="enum" name="VkExternalSemaphoreHandleTypeFlagBitsKHR" alias="VkExternalSemaphoreHandleTypeFlagBits"/>
+ <type name="VkExternalSemaphoreFeatureFlagBits" category="enum"/>
+ <type category="enum" name="VkExternalSemaphoreFeatureFlagBitsKHR" alias="VkExternalSemaphoreFeatureFlagBits"/>
+ <type name="VkSemaphoreImportFlagBits" category="enum"/>
+ <type category="enum" name="VkSemaphoreImportFlagBitsKHR" alias="VkSemaphoreImportFlagBits"/>
+ <type name="VkExternalFenceHandleTypeFlagBits" category="enum"/>
+ <type category="enum" name="VkExternalFenceHandleTypeFlagBitsKHR" alias="VkExternalFenceHandleTypeFlagBits"/>
+ <type name="VkExternalFenceFeatureFlagBits" category="enum"/>
+ <type category="enum" name="VkExternalFenceFeatureFlagBitsKHR" alias="VkExternalFenceFeatureFlagBits"/>
+ <type name="VkFenceImportFlagBits" category="enum"/>
+ <type category="enum" name="VkFenceImportFlagBitsKHR" alias="VkFenceImportFlagBits"/>
+ <type name="VkSurfaceCounterFlagBitsEXT" category="enum"/>
+ <type name="VkDisplayPowerStateEXT" category="enum"/>
+ <type name="VkDeviceEventTypeEXT" category="enum"/>
+ <type name="VkDisplayEventTypeEXT" category="enum"/>
+ <type name="VkPeerMemoryFeatureFlagBits" category="enum"/>
+ <type category="enum" name="VkPeerMemoryFeatureFlagBitsKHR" alias="VkPeerMemoryFeatureFlagBits"/>
+ <type name="VkMemoryAllocateFlagBits" category="enum"/>
+ <type category="enum" name="VkMemoryAllocateFlagBitsKHR" alias="VkMemoryAllocateFlagBits"/>
+ <type name="VkDeviceGroupPresentModeFlagBitsKHR" category="enum"/>
+ <type name="VkSwapchainCreateFlagBitsKHR" category="enum"/>
+ <type name="VkSubgroupFeatureFlagBits" category="enum"/>
+ <type name="VkTessellationDomainOrigin" category="enum"/>
+ <type category="enum" name="VkTessellationDomainOriginKHR" alias="VkTessellationDomainOrigin"/>
+ <type name="VkSamplerYcbcrModelConversion" category="enum"/>
+ <type category="enum" name="VkSamplerYcbcrModelConversionKHR" alias="VkSamplerYcbcrModelConversion"/>
+ <type name="VkSamplerYcbcrRange" category="enum"/>
+ <type category="enum" name="VkSamplerYcbcrRangeKHR" alias="VkSamplerYcbcrRange"/>
+ <type name="VkChromaLocation" category="enum"/>
+ <type category="enum" name="VkChromaLocationKHR" alias="VkChromaLocation"/>
+ <type name="VkSamplerReductionModeEXT" category="enum"/>
+ <type name="VkBlendOverlapEXT" category="enum"/>
+ <type name="VkDebugUtilsMessageSeverityFlagBitsEXT" category="enum"/>
+ <type name="VkDebugUtilsMessageTypeFlagBitsEXT" category="enum"/>
+
+ <comment>The PFN_vk*Function types are used by VkAllocationCallbacks below</comment>
+ <type category="funcpointer">typedef void (VKAPI_PTR *<name>PFN_vkInternalAllocationNotification</name>)(
+ <type>void</type>* pUserData,
+ <type>size_t</type> size,
+ <type>VkInternalAllocationType</type> allocationType,
+ <type>VkSystemAllocationScope</type> allocationScope);</type>
+ <type category="funcpointer">typedef void (VKAPI_PTR *<name>PFN_vkInternalFreeNotification</name>)(
+ <type>void</type>* pUserData,
+ <type>size_t</type> size,
+ <type>VkInternalAllocationType</type> allocationType,
+ <type>VkSystemAllocationScope</type> allocationScope);</type>
+ <type category="funcpointer">typedef void* (VKAPI_PTR *<name>PFN_vkReallocationFunction</name>)(
+ <type>void</type>* pUserData,
+ <type>void</type>* pOriginal,
+ <type>size_t</type> size,
+ <type>size_t</type> alignment,
+ <type>VkSystemAllocationScope</type> allocationScope);</type>
+ <type category="funcpointer">typedef void* (VKAPI_PTR *<name>PFN_vkAllocationFunction</name>)(
+ <type>void</type>* pUserData,
+ <type>size_t</type> size,
+ <type>size_t</type> alignment,
+ <type>VkSystemAllocationScope</type> allocationScope);</type>
+ <type category="funcpointer">typedef void (VKAPI_PTR *<name>PFN_vkFreeFunction</name>)(
+ <type>void</type>* pUserData,
+ <type>void</type>* pMemory);</type>
+
+ <comment>The PFN_vkVoidFunction type are used by VkGet*ProcAddr below</comment>
+ <type category="funcpointer">typedef void (VKAPI_PTR *<name>PFN_vkVoidFunction</name>)(void);</type>
+
+ <comment>The PFN_vkDebugReportCallbackEXT type are used by the DEBUG_REPORT extension</comment>
+ <type category="funcpointer">typedef VkBool32 (VKAPI_PTR *<name>PFN_vkDebugReportCallbackEXT</name>)(
+ <type>VkDebugReportFlagsEXT</type> flags,
+ <type>VkDebugReportObjectTypeEXT</type> objectType,
+ <type>uint64_t</type> object,
+ <type>size_t</type> location,
+ <type>int32_t</type> messageCode,
+ const <type>char</type>* pLayerPrefix,
+ const <type>char</type>* pMessage,
+ <type>void</type>* pUserData);</type>
+
+ <comment>The PFN_vkDebugUtilsMessengerCallbackEXT type are used by the VK_EXT_debug_utils extension</comment>
+ <type category="funcpointer" requires="VkDebugUtilsMessengerCallbackDataEXT">typedef VkBool32 (VKAPI_PTR *<name>PFN_vkDebugUtilsMessengerCallbackEXT</name>)(
+ <type>VkDebugUtilsMessageSeverityFlagBitsEXT</type> messageSeverity,
+ <type>VkDebugUtilsMessageTypeFlagsEXT</type> messageType,
+ const <type>VkDebugUtilsMessengerCallbackDataEXT</type>* pCallbackData,
+ <type>void</type>* pUserData);</type>
+
+ <comment>Struct types</comment>
+ <type category="struct" name="VkOffset2D">
+ <member><type>int32_t</type> <name>x</name></member>
+ <member><type>int32_t</type> <name>y</name></member>
+ </type>
+ <type category="struct" name="VkOffset3D">
+ <member><type>int32_t</type> <name>x</name></member>
+ <member><type>int32_t</type> <name>y</name></member>
+ <member><type>int32_t</type> <name>z</name></member>
+ </type>
+ <type category="struct" name="VkExtent2D">
+ <member><type>uint32_t</type> <name>width</name></member>
+ <member><type>uint32_t</type> <name>height</name></member>
+ </type>
+ <type category="struct" name="VkExtent3D">
+ <member><type>uint32_t</type> <name>width</name></member>
+ <member><type>uint32_t</type> <name>height</name></member>
+ <member><type>uint32_t</type> <name>depth</name></member>
+ </type>
+ <type category="struct" name="VkViewport">
+ <member><type>float</type> <name>x</name></member>
+ <member><type>float</type> <name>y</name></member>
+ <member><type>float</type> <name>width</name></member>
+ <member><type>float</type> <name>height</name></member>
+ <member><type>float</type> <name>minDepth</name></member>
+ <member><type>float</type> <name>maxDepth</name></member>
+ </type>
+ <type category="struct" name="VkRect2D">
+ <member><type>VkOffset2D</type> <name>offset</name></member>
+ <member><type>VkExtent2D</type> <name>extent</name></member>
+ </type>
+ <type category="struct" name="VkClearRect">
+ <member><type>VkRect2D</type> <name>rect</name></member>
+ <member><type>uint32_t</type> <name>baseArrayLayer</name></member>
+ <member><type>uint32_t</type> <name>layerCount</name></member>
+ </type>
+ <type category="struct" name="VkComponentMapping">
+ <member><type>VkComponentSwizzle</type> <name>r</name></member>
+ <member><type>VkComponentSwizzle</type> <name>g</name></member>
+ <member><type>VkComponentSwizzle</type> <name>b</name></member>
+ <member><type>VkComponentSwizzle</type> <name>a</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceProperties" returnedonly="true">
+ <member><type>uint32_t</type> <name>apiVersion</name></member>
+ <member><type>uint32_t</type> <name>driverVersion</name></member>
+ <member><type>uint32_t</type> <name>vendorID</name></member>
+ <member><type>uint32_t</type> <name>deviceID</name></member>
+ <member><type>VkPhysicalDeviceType</type> <name>deviceType</name></member>
+ <member><type>char</type> <name>deviceName</name>[<enum>VK_MAX_PHYSICAL_DEVICE_NAME_SIZE</enum>]</member>
+ <member><type>uint8_t</type> <name>pipelineCacheUUID</name>[<enum>VK_UUID_SIZE</enum>]</member>
+ <member><type>VkPhysicalDeviceLimits</type> <name>limits</name></member>
+ <member><type>VkPhysicalDeviceSparseProperties</type> <name>sparseProperties</name></member>
+ </type>
+ <type category="struct" name="VkExtensionProperties" returnedonly="true">
+ <member><type>char</type> <name>extensionName</name>[<enum>VK_MAX_EXTENSION_NAME_SIZE</enum>]<comment>extension name</comment></member>
+ <member><type>uint32_t</type> <name>specVersion</name><comment>version of the extension specification implemented</comment></member>
+ </type>
+ <type category="struct" name="VkLayerProperties" returnedonly="true">
+ <member><type>char</type> <name>layerName</name>[<enum>VK_MAX_EXTENSION_NAME_SIZE</enum>]<comment>layer name</comment></member>
+ <member><type>uint32_t</type> <name>specVersion</name><comment>version of the layer specification implemented</comment></member>
+ <member><type>uint32_t</type> <name>implementationVersion</name><comment>build or release version of the layer's library</comment></member>
+ <member><type>char</type> <name>description</name>[<enum>VK_MAX_DESCRIPTION_SIZE</enum>]<comment>Free-form description of the layer</comment></member>
+ </type>
+ <type category="struct" name="VkApplicationInfo">
+ <member values="VK_STRUCTURE_TYPE_APPLICATION_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true" len="null-terminated">const <type>char</type>* <name>pApplicationName</name></member>
+ <member><type>uint32_t</type> <name>applicationVersion</name></member>
+ <member optional="true" len="null-terminated">const <type>char</type>* <name>pEngineName</name></member>
+ <member><type>uint32_t</type> <name>engineVersion</name></member>
+ <member><type>uint32_t</type> <name>apiVersion</name></member>
+ </type>
+ <type category="struct" name="VkAllocationCallbacks">
+ <member optional="true"><type>void</type>* <name>pUserData</name></member>
+ <member><type>PFN_vkAllocationFunction</type> <name>pfnAllocation</name></member>
+ <member><type>PFN_vkReallocationFunction</type> <name>pfnReallocation</name></member>
+ <member><type>PFN_vkFreeFunction</type> <name>pfnFree</name></member>
+ <member optional="true"><type>PFN_vkInternalAllocationNotification</type> <name>pfnInternalAllocation</name></member>
+ <member optional="true"><type>PFN_vkInternalFreeNotification</type> <name>pfnInternalFree</name></member>
+ </type>
+ <type category="struct" name="VkDeviceQueueCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDeviceQueueCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>queueFamilyIndex</name></member>
+ <member><type>uint32_t</type> <name>queueCount</name></member>
+ <member len="queueCount">const <type>float</type>* <name>pQueuePriorities</name></member>
+ </type>
+ <type category="struct" name="VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDeviceCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>queueCreateInfoCount</name></member>
+ <member len="queueCreateInfoCount">const <type>VkDeviceQueueCreateInfo</type>* <name>pQueueCreateInfos</name></member>
+ <member optional="true"><type>uint32_t</type> <name>enabledLayerCount</name></member>
+ <member len="enabledLayerCount,null-terminated">const <type>char</type>* const* <name>ppEnabledLayerNames</name><comment>Ordered list of layer names to be enabled</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>enabledExtensionCount</name></member>
+ <member len="enabledExtensionCount,null-terminated">const <type>char</type>* const* <name>ppEnabledExtensionNames</name></member>
+ <member optional="true">const <type>VkPhysicalDeviceFeatures</type>* <name>pEnabledFeatures</name></member>
+ </type>
+ <type category="struct" name="VkInstanceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkInstanceCreateFlags</type> <name>flags</name></member>
+ <member optional="true">const <type>VkApplicationInfo</type>* <name>pApplicationInfo</name></member>
+ <member optional="true"><type>uint32_t</type> <name>enabledLayerCount</name></member>
+ <member len="enabledLayerCount,null-terminated">const <type>char</type>* const* <name>ppEnabledLayerNames</name><comment>Ordered list of layer names to be enabled</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>enabledExtensionCount</name></member>
+ <member len="enabledExtensionCount,null-terminated">const <type>char</type>* const* <name>ppEnabledExtensionNames</name><comment>Extension names to be enabled</comment></member>
+ </type>
+ <type category="struct" name="VkQueueFamilyProperties" returnedonly="true">
+ <member optional="true"><type>VkQueueFlags</type> <name>queueFlags</name><comment>Queue flags</comment></member>
+ <member><type>uint32_t</type> <name>queueCount</name></member>
+ <member><type>uint32_t</type> <name>timestampValidBits</name></member>
+ <member><type>VkExtent3D</type> <name>minImageTransferGranularity</name><comment>Minimum alignment requirement for image transfers</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMemoryProperties" returnedonly="true">
+ <member><type>uint32_t</type> <name>memoryTypeCount</name></member>
+ <member><type>VkMemoryType</type> <name>memoryTypes</name>[<enum>VK_MAX_MEMORY_TYPES</enum>]</member>
+ <member><type>uint32_t</type> <name>memoryHeapCount</name></member>
+ <member><type>VkMemoryHeap</type> <name>memoryHeaps</name>[<enum>VK_MAX_MEMORY_HEAPS</enum>]</member>
+ </type>
+ <type category="struct" name="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceSize</type> <name>allocationSize</name><comment>Size of memory allocation</comment></member>
+ <member><type>uint32_t</type> <name>memoryTypeIndex</name><comment>Index of the of the memory type to allocate from</comment></member>
+ </type>
+ <type category="struct" name="VkMemoryRequirements" returnedonly="true">
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>alignment</name><comment>Specified in bytes</comment></member>
+ <member><type>uint32_t</type> <name>memoryTypeBits</name><comment>Bitmask of the allowed memory type indices into memoryTypes[] for this object</comment></member>
+ </type>
+ <type category="struct" name="VkSparseImageFormatProperties" returnedonly="true">
+ <member optional="true"><type>VkImageAspectFlags</type> <name>aspectMask</name></member>
+ <member><type>VkExtent3D</type> <name>imageGranularity</name></member>
+ <member optional="true"><type>VkSparseImageFormatFlags</type> <name>flags</name></member>
+ </type>
+ <type category="struct" name="VkSparseImageMemoryRequirements" returnedonly="true">
+ <member><type>VkSparseImageFormatProperties</type> <name>formatProperties</name></member>
+ <member><type>uint32_t</type> <name>imageMipTailFirstLod</name></member>
+ <member><type>VkDeviceSize</type> <name>imageMipTailSize</name><comment>Specified in bytes, must be a multiple of sparse block size in bytes / alignment</comment></member>
+ <member><type>VkDeviceSize</type> <name>imageMipTailOffset</name><comment>Specified in bytes, must be a multiple of sparse block size in bytes / alignment</comment></member>
+ <member><type>VkDeviceSize</type> <name>imageMipTailStride</name><comment>Specified in bytes, must be a multiple of sparse block size in bytes / alignment</comment></member>
+ </type>
+ <type category="struct" name="VkMemoryType" returnedonly="true">
+ <member optional="true"><type>VkMemoryPropertyFlags</type> <name>propertyFlags</name><comment>Memory properties of this memory type</comment></member>
+ <member><type>uint32_t</type> <name>heapIndex</name><comment>Index of the memory heap allocations of this memory type are taken from</comment></member>
+ </type>
+ <type category="struct" name="VkMemoryHeap" returnedonly="true">
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Available memory in the heap</comment></member>
+ <member optional="true"><type>VkMemoryHeapFlags</type> <name>flags</name><comment>Flags for the heap</comment></member>
+ </type>
+ <type category="struct" name="VkMappedMemoryRange">
+ <member values="VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceMemory</type> <name>memory</name><comment>Mapped memory object</comment></member>
+ <member><type>VkDeviceSize</type> <name>offset</name><comment>Offset within the memory object where the range starts</comment></member>
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Size of the range within the memory object</comment></member>
+ </type>
+ <type category="struct" name="VkFormatProperties" returnedonly="true">
+ <member optional="true"><type>VkFormatFeatureFlags</type> <name>linearTilingFeatures</name><comment>Format features in case of linear tiling</comment></member>
+ <member optional="true"><type>VkFormatFeatureFlags</type> <name>optimalTilingFeatures</name><comment>Format features in case of optimal tiling</comment></member>
+ <member optional="true"><type>VkFormatFeatureFlags</type> <name>bufferFeatures</name><comment>Format features supported by buffers</comment></member>
+ </type>
+ <type category="struct" name="VkImageFormatProperties" returnedonly="true">
+ <member><type>VkExtent3D</type> <name>maxExtent</name><comment>max image dimensions for this resource type</comment></member>
+ <member><type>uint32_t</type> <name>maxMipLevels</name><comment>max number of mipmap levels for this resource type</comment></member>
+ <member><type>uint32_t</type> <name>maxArrayLayers</name><comment>max array size for this resource type</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>sampleCounts</name><comment>supported sample counts for this resource type</comment></member>
+ <member><type>VkDeviceSize</type> <name>maxResourceSize</name><comment>max size (in bytes) of this resource type</comment></member>
+ </type>
+ <type category="struct" name="VkDescriptorBufferInfo">
+ <member><type>VkBuffer</type> <name>buffer</name><comment>Buffer used for this descriptor slot when the descriptor is UNIFORM_BUFFER[_DYNAMIC] or STORAGE_BUFFER[_DYNAMIC]. VK_NULL_HANDLE otherwise.</comment></member>
+ <member><type>VkDeviceSize</type> <name>offset</name><comment>Base offset from buffer start in bytes to update in the descriptor set.</comment></member>
+ <member><type>VkDeviceSize</type> <name>range</name><comment>Size in bytes of the buffer resource for this descriptor update.</comment></member>
+ </type>
+ <type category="struct" name="VkDescriptorImageInfo">
+ <member noautovalidity="true"><type>VkSampler</type> <name>sampler</name><comment>Sampler to write to the descriptor in case it is a SAMPLER or COMBINED_IMAGE_SAMPLER descriptor. Ignored otherwise.</comment></member>
+ <member noautovalidity="true"><type>VkImageView</type> <name>imageView</name><comment>Image view to write to the descriptor in case it is a SAMPLED_IMAGE, STORAGE_IMAGE, COMBINED_IMAGE_SAMPLER, or INPUT_ATTACHMENT descriptor. Ignored otherwise.</comment></member>
+ <member noautovalidity="true"><type>VkImageLayout</type> <name>imageLayout</name><comment>Layout the image is expected to be in when accessed using this descriptor (only used if imageView is not VK_NULL_HANDLE).</comment></member>
+ </type>
+ <type category="struct" name="VkWriteDescriptorSet">
+ <member values="VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member noautovalidity="true"><type>VkDescriptorSet</type> <name>dstSet</name><comment>Destination descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>dstBinding</name><comment>Binding within the destination descriptor set to write</comment></member>
+ <member><type>uint32_t</type> <name>dstArrayElement</name><comment>Array element within the destination binding to write</comment></member>
+ <member><type>uint32_t</type> <name>descriptorCount</name><comment>Number of descriptors to write (determines the size of the array pointed by pDescriptors)</comment></member>
+ <member><type>VkDescriptorType</type> <name>descriptorType</name><comment>Descriptor type to write (determines which members of the array pointed by pDescriptors are going to be used)</comment></member>
+ <member noautovalidity="true" len="descriptorCount">const <type>VkDescriptorImageInfo</type>* <name>pImageInfo</name><comment>Sampler, image view, and layout for SAMPLER, COMBINED_IMAGE_SAMPLER, {SAMPLED,STORAGE}_IMAGE, and INPUT_ATTACHMENT descriptor types.</comment></member>
+ <member noautovalidity="true" len="descriptorCount">const <type>VkDescriptorBufferInfo</type>* <name>pBufferInfo</name><comment>Raw buffer, size, and offset for {UNIFORM,STORAGE}_BUFFER[_DYNAMIC] descriptor types.</comment></member>
+ <member noautovalidity="true" len="descriptorCount">const <type>VkBufferView</type>* <name>pTexelBufferView</name><comment>Buffer view to write to the descriptor for {UNIFORM,STORAGE}_TEXEL_BUFFER descriptor types.</comment></member>
+ </type>
+ <type category="struct" name="VkCopyDescriptorSet">
+ <member values="VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDescriptorSet</type> <name>srcSet</name><comment>Source descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>srcBinding</name><comment>Binding within the source descriptor set to copy from</comment></member>
+ <member><type>uint32_t</type> <name>srcArrayElement</name><comment>Array element within the source binding to copy from</comment></member>
+ <member><type>VkDescriptorSet</type> <name>dstSet</name><comment>Destination descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>dstBinding</name><comment>Binding within the destination descriptor set to copy to</comment></member>
+ <member><type>uint32_t</type> <name>dstArrayElement</name><comment>Array element within the destination binding to copy to</comment></member>
+ <member><type>uint32_t</type> <name>descriptorCount</name><comment>Number of descriptors to write (determines the size of the array pointed by pDescriptors)</comment></member>
+ </type>
+ <type category="struct" name="VkBufferCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkBufferCreateFlags</type> <name>flags</name><comment>Buffer creation flags</comment></member>
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Specified in bytes</comment></member>
+ <member><type>VkBufferUsageFlags</type> <name>usage</name><comment>Buffer usage flags</comment></member>
+ <member><type>VkSharingMode</type> <name>sharingMode</name></member>
+ <member optional="true"><type>uint32_t</type> <name>queueFamilyIndexCount</name></member>
+ <member noautovalidity="true" len="queueFamilyIndexCount">const <type>uint32_t</type>* <name>pQueueFamilyIndices</name></member>
+ </type>
+ <type category="struct" name="VkBufferViewCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkBufferViewCreateFlags</type><name>flags</name></member>
+ <member><type>VkBuffer</type> <name>buffer</name></member>
+ <member><type>VkFormat</type> <name>format</name><comment>Optionally specifies format of elements</comment></member>
+ <member><type>VkDeviceSize</type> <name>offset</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>range</name><comment>View size specified in bytes</comment></member>
+ </type>
+ <type category="struct" name="VkImageSubresource">
+ <member><type>VkImageAspectFlags</type> <name>aspectMask</name></member>
+ <member><type>uint32_t</type> <name>mipLevel</name></member>
+ <member><type>uint32_t</type> <name>arrayLayer</name></member>
+ </type>
+ <type category="struct" name="VkImageSubresourceLayers">
+ <member><type>VkImageAspectFlags</type> <name>aspectMask</name></member>
+ <member><type>uint32_t</type> <name>mipLevel</name></member>
+ <member><type>uint32_t</type> <name>baseArrayLayer</name></member>
+ <member><type>uint32_t</type> <name>layerCount</name></member>
+ </type>
+ <type category="struct" name="VkImageSubresourceRange">
+ <member><type>VkImageAspectFlags</type> <name>aspectMask</name></member>
+ <member><type>uint32_t</type> <name>baseMipLevel</name></member>
+ <member><type>uint32_t</type> <name>levelCount</name></member>
+ <member><type>uint32_t</type> <name>baseArrayLayer</name></member>
+ <member><type>uint32_t</type> <name>layerCount</name></member>
+ </type>
+ <type category="struct" name="VkMemoryBarrier">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_BARRIER"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>srcAccessMask</name><comment>Memory accesses from the source of the dependency to synchronize</comment></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>dstAccessMask</name><comment>Memory accesses from the destination of the dependency to synchronize</comment></member>
+ </type>
+ <type category="struct" name="VkBufferMemoryBarrier">
+ <member values="VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>srcAccessMask</name><comment>Memory accesses from the source of the dependency to synchronize</comment></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>dstAccessMask</name><comment>Memory accesses from the destination of the dependency to synchronize</comment></member>
+ <member><type>uint32_t</type> <name>srcQueueFamilyIndex</name><comment>Queue family to transition ownership from</comment></member>
+ <member><type>uint32_t</type> <name>dstQueueFamilyIndex</name><comment>Queue family to transition ownership to</comment></member>
+ <member><type>VkBuffer</type> <name>buffer</name><comment>Buffer to sync</comment></member>
+ <member><type>VkDeviceSize</type> <name>offset</name><comment>Offset within the buffer to sync</comment></member>
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Amount of bytes to sync</comment></member>
+ </type>
+ <type category="struct" name="VkImageMemoryBarrier">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>srcAccessMask</name><comment>Memory accesses from the source of the dependency to synchronize</comment></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>dstAccessMask</name><comment>Memory accesses from the destination of the dependency to synchronize</comment></member>
+ <member><type>VkImageLayout</type> <name>oldLayout</name><comment>Current layout of the image</comment></member>
+ <member><type>VkImageLayout</type> <name>newLayout</name><comment>New layout to transition the image to</comment></member>
+ <member><type>uint32_t</type> <name>srcQueueFamilyIndex</name><comment>Queue family to transition ownership from</comment></member>
+ <member><type>uint32_t</type> <name>dstQueueFamilyIndex</name><comment>Queue family to transition ownership to</comment></member>
+ <member><type>VkImage</type> <name>image</name><comment>Image to sync</comment></member>
+ <member><type>VkImageSubresourceRange</type> <name>subresourceRange</name><comment>Subresource range to sync</comment></member>
+ </type>
+ <type category="struct" name="VkImageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkImageCreateFlags</type> <name>flags</name><comment>Image creation flags</comment></member>
+ <member><type>VkImageType</type> <name>imageType</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>VkExtent3D</type> <name>extent</name></member>
+ <member><type>uint32_t</type> <name>mipLevels</name></member>
+ <member><type>uint32_t</type> <name>arrayLayers</name></member>
+ <member><type>VkSampleCountFlagBits</type> <name>samples</name></member>
+ <member><type>VkImageTiling</type> <name>tiling</name></member>
+ <member><type>VkImageUsageFlags</type> <name>usage</name><comment>Image usage flags</comment></member>
+ <member><type>VkSharingMode</type> <name>sharingMode</name><comment>Cross-queue-family sharing mode</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>queueFamilyIndexCount</name><comment>Number of queue families to share across</comment></member>
+ <member noautovalidity="true" len="queueFamilyIndexCount">const <type>uint32_t</type>* <name>pQueueFamilyIndices</name><comment>Array of queue family indices to share across</comment></member>
+ <member><type>VkImageLayout</type> <name>initialLayout</name><comment>Initial image layout for all subresources</comment></member>
+ </type>
+ <type category="struct" name="VkSubresourceLayout" returnedonly="true">
+ <member><type>VkDeviceSize</type> <name>offset</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>rowPitch</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>arrayPitch</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>depthPitch</name><comment>Specified in bytes</comment></member>
+ </type>
+ <type category="struct" name="VkImageViewCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkImageViewCreateFlags</type> <name>flags</name></member>
+ <member><type>VkImage</type> <name>image</name></member>
+ <member><type>VkImageViewType</type> <name>viewType</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>VkComponentMapping</type> <name>components</name></member>
+ <member><type>VkImageSubresourceRange</type> <name>subresourceRange</name></member>
+ </type>
+ <type category="struct" name="VkBufferCopy">
+ <member><type>VkDeviceSize</type> <name>srcOffset</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>dstOffset</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Specified in bytes</comment></member>
+ </type>
+ <type category="struct" name="VkSparseMemoryBind">
+ <member><type>VkDeviceSize</type> <name>resourceOffset</name><comment>Specified in bytes</comment></member>
+ <member><type>VkDeviceSize</type> <name>size</name><comment>Specified in bytes</comment></member>
+ <member optional="true"><type>VkDeviceMemory</type> <name>memory</name></member>
+ <member><type>VkDeviceSize</type> <name>memoryOffset</name><comment>Specified in bytes</comment></member>
+ <member optional="true"><type>VkSparseMemoryBindFlags</type><name>flags</name></member>
+ </type>
+ <type category="struct" name="VkSparseImageMemoryBind">
+ <member><type>VkImageSubresource</type> <name>subresource</name></member>
+ <member><type>VkOffset3D</type> <name>offset</name></member>
+ <member><type>VkExtent3D</type> <name>extent</name></member>
+ <member optional="true"><type>VkDeviceMemory</type> <name>memory</name></member>
+ <member><type>VkDeviceSize</type> <name>memoryOffset</name><comment>Specified in bytes</comment></member>
+ <member optional="true"><type>VkSparseMemoryBindFlags</type><name>flags</name></member>
+ </type>
+ <type category="struct" name="VkSparseBufferMemoryBindInfo">
+ <member><type>VkBuffer</type> <name>buffer</name></member>
+ <member><type>uint32_t</type> <name>bindCount</name></member>
+ <member len="bindCount">const <type>VkSparseMemoryBind</type>* <name>pBinds</name></member>
+ </type>
+ <type category="struct" name="VkSparseImageOpaqueMemoryBindInfo">
+ <member><type>VkImage</type> <name>image</name></member>
+ <member><type>uint32_t</type> <name>bindCount</name></member>
+ <member len="bindCount">const <type>VkSparseMemoryBind</type>* <name>pBinds</name></member>
+ </type>
+ <type category="struct" name="VkSparseImageMemoryBindInfo">
+ <member><type>VkImage</type> <name>image</name></member>
+ <member><type>uint32_t</type> <name>bindCount</name></member>
+ <member len="bindCount">const <type>VkSparseImageMemoryBind</type>* <name>pBinds</name></member>
+ </type>
+ <type category="struct" name="VkBindSparseInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_SPARSE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>waitSemaphoreCount</name></member>
+ <member len="waitSemaphoreCount">const <type>VkSemaphore</type>* <name>pWaitSemaphores</name></member>
+ <member optional="true"><type>uint32_t</type> <name>bufferBindCount</name></member>
+ <member len="bufferBindCount">const <type>VkSparseBufferMemoryBindInfo</type>* <name>pBufferBinds</name></member>
+ <member optional="true"><type>uint32_t</type> <name>imageOpaqueBindCount</name></member>
+ <member len="imageOpaqueBindCount">const <type>VkSparseImageOpaqueMemoryBindInfo</type>* <name>pImageOpaqueBinds</name></member>
+ <member optional="true"><type>uint32_t</type> <name>imageBindCount</name></member>
+ <member len="imageBindCount">const <type>VkSparseImageMemoryBindInfo</type>* <name>pImageBinds</name></member>
+ <member optional="true"><type>uint32_t</type> <name>signalSemaphoreCount</name></member>
+ <member len="signalSemaphoreCount">const <type>VkSemaphore</type>* <name>pSignalSemaphores</name></member>
+ </type>
+ <type category="struct" name="VkImageCopy">
+ <member><type>VkImageSubresourceLayers</type> <name>srcSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>srcOffset</name><comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ <member><type>VkImageSubresourceLayers</type> <name>dstSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>dstOffset</name><comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ <member><type>VkExtent3D</type> <name>extent</name><comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ </type>
+ <type category="struct" name="VkImageBlit">
+ <member><type>VkImageSubresourceLayers</type> <name>srcSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>srcOffsets</name>[2]<comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ <member><type>VkImageSubresourceLayers</type> <name>dstSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>dstOffsets</name>[2]<comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ </type>
+ <type category="struct" name="VkBufferImageCopy">
+ <member><type>VkDeviceSize</type> <name>bufferOffset</name><comment>Specified in bytes</comment></member>
+ <member><type>uint32_t</type> <name>bufferRowLength</name><comment>Specified in texels</comment></member>
+ <member><type>uint32_t</type> <name>bufferImageHeight</name></member>
+ <member><type>VkImageSubresourceLayers</type> <name>imageSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>imageOffset</name><comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ <member><type>VkExtent3D</type> <name>imageExtent</name><comment>Specified in pixels for both compressed and uncompressed images</comment></member>
+ </type>
+ <type category="struct" name="VkImageResolve">
+ <member><type>VkImageSubresourceLayers</type> <name>srcSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>srcOffset</name></member>
+ <member><type>VkImageSubresourceLayers</type> <name>dstSubresource</name></member>
+ <member><type>VkOffset3D</type> <name>dstOffset</name></member>
+ <member><type>VkExtent3D</type> <name>extent</name></member>
+ </type>
+ <type category="struct" name="VkShaderModuleCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkShaderModuleCreateFlags</type> <name>flags</name></member>
+ <member><type>size_t</type> <name>codeSize</name><comment>Specified in bytes</comment></member>
+ <member len="latexmath:[codeSize \over 4]" altlen="codeSize / 4">const <type>uint32_t</type>* <name>pCode</name><comment>Binary code of size codeSize</comment></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetLayoutBinding">
+ <member><type>uint32_t</type> <name>binding</name><comment>Binding number for this entry</comment></member>
+ <member><type>VkDescriptorType</type> <name>descriptorType</name><comment>Type of the descriptors in this binding</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>descriptorCount</name><comment>Number of descriptors in this binding</comment></member>
+ <member noautovalidity="true"><type>VkShaderStageFlags</type> <name>stageFlags</name><comment>Shader stages this binding is visible to</comment></member>
+ <member noautovalidity="true" optional="true" len="descriptorCount">const <type>VkSampler</type>* <name>pImmutableSamplers</name><comment>Immutable samplers (used if descriptor type is SAMPLER or COMBINED_IMAGE_SAMPLER, is either NULL or contains count number of elements)</comment></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetLayoutCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDescriptorSetLayoutCreateFlags</type> <name>flags</name></member>
+ <member optional="true"><type>uint32_t</type> <name>bindingCount</name><comment>Number of bindings in the descriptor set layout</comment></member>
+ <member len="bindingCount">const <type>VkDescriptorSetLayoutBinding</type>* <name>pBindings</name><comment>Array of descriptor set layout bindings</comment></member>
+ </type>
+ <type category="struct" name="VkDescriptorPoolSize">
+ <member><type>VkDescriptorType</type> <name>type</name></member>
+ <member><type>uint32_t</type> <name>descriptorCount</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorPoolCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDescriptorPoolCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>maxSets</name></member>
+ <member><type>uint32_t</type> <name>poolSizeCount</name></member>
+ <member len="poolSizeCount">const <type>VkDescriptorPoolSize</type>* <name>pPoolSizes</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDescriptorPool</type> <name>descriptorPool</name></member>
+ <member><type>uint32_t</type> <name>descriptorSetCount</name></member>
+ <member len="descriptorSetCount">const <type>VkDescriptorSetLayout</type>* <name>pSetLayouts</name></member>
+ </type>
+ <type category="struct" name="VkSpecializationMapEntry">
+ <member><type>uint32_t</type> <name>constantID</name><comment>The SpecConstant ID specified in the BIL</comment></member>
+ <member><type>uint32_t</type> <name>offset</name><comment>Offset of the value in the data block</comment></member>
+ <member><type>size_t</type> <name>size</name><comment>Size in bytes of the SpecConstant</comment></member>
+ </type>
+ <type category="struct" name="VkSpecializationInfo">
+ <member optional="true"><type>uint32_t</type> <name>mapEntryCount</name><comment>Number of entries in the map</comment></member>
+ <member len="mapEntryCount" noautovalidity="true">const <type>VkSpecializationMapEntry</type>* <name>pMapEntries</name><comment>Array of map entries</comment></member>
+ <member optional="true"><type>size_t</type> <name>dataSize</name><comment>Size in bytes of pData</comment></member>
+ <member len="dataSize">const <type>void</type>* <name>pData</name><comment>Pointer to SpecConstant data</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineShaderStageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineShaderStageCreateFlags</type> <name>flags</name></member>
+ <member><type>VkShaderStageFlagBits</type> <name>stage</name><comment>Shader stage</comment></member>
+ <member><type>VkShaderModule</type> <name>module</name><comment>Module containing entry point</comment></member>
+ <member len="null-terminated">const <type>char</type>* <name>pName</name><comment>Null-terminated entry point name</comment></member>
+ <member optional="true">const <type>VkSpecializationInfo</type>* <name>pSpecializationInfo</name></member>
+ </type>
+ <type category="struct" name="VkComputePipelineCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineCreateFlags</type> <name>flags</name><comment>Pipeline creation flags</comment></member>
+ <member><type>VkPipelineShaderStageCreateInfo</type> <name>stage</name></member>
+ <member><type>VkPipelineLayout</type> <name>layout</name><comment>Interface layout of the pipeline</comment></member>
+ <member noautovalidity="true" optional="true"><type>VkPipeline</type> <name>basePipelineHandle</name><comment>If VK_PIPELINE_CREATE_DERIVATIVE_BIT is set and this value is nonzero, it specifies the handle of the base pipeline this is a derivative of</comment></member>
+ <member><type>int32_t</type> <name>basePipelineIndex</name><comment>If VK_PIPELINE_CREATE_DERIVATIVE_BIT is set and this value is not -1, it specifies an index into pCreateInfos of the base pipeline this is a derivative of</comment></member>
+ </type>
+ <type category="struct" name="VkVertexInputBindingDescription">
+ <member><type>uint32_t</type> <name>binding</name><comment>Vertex buffer binding id</comment></member>
+ <member><type>uint32_t</type> <name>stride</name><comment>Distance between vertices in bytes (0 = no advancement)</comment></member>
+ <member><type>VkVertexInputRate</type> <name>inputRate</name><comment>The rate at which the vertex data is consumed</comment></member>
+ </type>
+ <type category="struct" name="VkVertexInputAttributeDescription">
+ <member><type>uint32_t</type> <name>location</name><comment>location of the shader vertex attrib</comment></member>
+ <member><type>uint32_t</type> <name>binding</name><comment>Vertex buffer binding id</comment></member>
+ <member><type>VkFormat</type> <name>format</name><comment>format of source data</comment></member>
+ <member><type>uint32_t</type> <name>offset</name><comment>Offset of first element in bytes from base of vertex</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineVertexInputStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineVertexInputStateCreateFlags</type> <name>flags</name></member>
+ <member optional="true"><type>uint32_t</type> <name>vertexBindingDescriptionCount</name><comment>number of bindings</comment></member>
+ <member len="vertexBindingDescriptionCount">const <type>VkVertexInputBindingDescription</type>* <name>pVertexBindingDescriptions</name></member>
+ <member optional="true"><type>uint32_t</type> <name>vertexAttributeDescriptionCount</name><comment>number of attributes</comment></member>
+ <member len="vertexAttributeDescriptionCount">const <type>VkVertexInputAttributeDescription</type>* <name>pVertexAttributeDescriptions</name></member>
+ </type>
+ <type category="struct" name="VkPipelineInputAssemblyStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineInputAssemblyStateCreateFlags</type> <name>flags</name></member>
+ <member><type>VkPrimitiveTopology</type> <name>topology</name></member>
+ <member><type>VkBool32</type> <name>primitiveRestartEnable</name></member>
+ </type>
+ <type category="struct" name="VkPipelineTessellationStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineTessellationStateCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>patchControlPoints</name></member>
+ </type>
+ <type category="struct" name="VkPipelineViewportStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineViewportStateCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>viewportCount</name></member>
+ <member noautovalidity="true" optional="true" len="viewportCount">const <type>VkViewport</type>* <name>pViewports</name></member>
+ <member><type>uint32_t</type> <name>scissorCount</name></member>
+ <member noautovalidity="true" optional="true" len="scissorCount">const <type>VkRect2D</type>* <name>pScissors</name></member>
+ </type>
+ <type category="struct" name="VkPipelineRasterizationStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineRasterizationStateCreateFlags</type> <name>flags</name></member>
+ <member><type>VkBool32</type> <name>depthClampEnable</name></member>
+ <member><type>VkBool32</type> <name>rasterizerDiscardEnable</name></member>
+ <member><type>VkPolygonMode</type> <name>polygonMode</name><comment>optional (GL45)</comment></member>
+ <member optional="true"><type>VkCullModeFlags</type> <name>cullMode</name></member>
+ <member><type>VkFrontFace</type> <name>frontFace</name></member>
+ <member><type>VkBool32</type> <name>depthBiasEnable</name></member>
+ <member><type>float</type> <name>depthBiasConstantFactor</name></member>
+ <member><type>float</type> <name>depthBiasClamp</name></member>
+ <member><type>float</type> <name>depthBiasSlopeFactor</name></member>
+ <member><type>float</type> <name>lineWidth</name></member>
+ </type>
+ <type category="struct" name="VkPipelineMultisampleStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineMultisampleStateCreateFlags</type> <name>flags</name></member>
+ <member><type>VkSampleCountFlagBits</type> <name>rasterizationSamples</name><comment>Number of samples used for rasterization</comment></member>
+ <member><type>VkBool32</type> <name>sampleShadingEnable</name><comment>optional (GL45)</comment></member>
+ <member><type>float</type> <name>minSampleShading</name><comment>optional (GL45)</comment></member>
+ <member optional="true" len="latexmath:[\lceil{\mathit{rasterizationSamples} \over 32}\rceil]" altlen="(rasterizationSamples + 31) / 32">const <type>VkSampleMask</type>* <name>pSampleMask</name><comment>Array of sampleMask words</comment></member>
+ <member><type>VkBool32</type> <name>alphaToCoverageEnable</name></member>
+ <member><type>VkBool32</type> <name>alphaToOneEnable</name></member>
+ </type>
+ <type category="struct" name="VkPipelineColorBlendAttachmentState">
+ <member><type>VkBool32</type> <name>blendEnable</name></member>
+ <member><type>VkBlendFactor</type> <name>srcColorBlendFactor</name></member>
+ <member><type>VkBlendFactor</type> <name>dstColorBlendFactor</name></member>
+ <member><type>VkBlendOp</type> <name>colorBlendOp</name></member>
+ <member><type>VkBlendFactor</type> <name>srcAlphaBlendFactor</name></member>
+ <member><type>VkBlendFactor</type> <name>dstAlphaBlendFactor</name></member>
+ <member><type>VkBlendOp</type> <name>alphaBlendOp</name></member>
+ <member optional="true"><type>VkColorComponentFlags</type> <name>colorWriteMask</name></member>
+ </type>
+ <type category="struct" name="VkPipelineColorBlendStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineColorBlendStateCreateFlags</type> <name>flags</name></member>
+ <member><type>VkBool32</type> <name>logicOpEnable</name></member>
+ <member noautovalidity="true"><type>VkLogicOp</type> <name>logicOp</name></member>
+ <member optional="true"><type>uint32_t</type> <name>attachmentCount</name><comment># of pAttachments</comment></member>
+ <member len="attachmentCount">const <type>VkPipelineColorBlendAttachmentState</type>* <name>pAttachments</name></member>
+ <member><type>float</type> <name>blendConstants</name>[4]</member>
+ </type>
+ <type category="struct" name="VkPipelineDynamicStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineDynamicStateCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>dynamicStateCount</name></member>
+ <member len="dynamicStateCount">const <type>VkDynamicState</type>* <name>pDynamicStates</name></member>
+ </type>
+ <type category="struct" name="VkStencilOpState">
+ <member><type>VkStencilOp</type> <name>failOp</name></member>
+ <member><type>VkStencilOp</type> <name>passOp</name></member>
+ <member><type>VkStencilOp</type> <name>depthFailOp</name></member>
+ <member><type>VkCompareOp</type> <name>compareOp</name></member>
+ <member><type>uint32_t</type> <name>compareMask</name></member>
+ <member><type>uint32_t</type> <name>writeMask</name></member>
+ <member><type>uint32_t</type> <name>reference</name></member>
+ </type>
+ <type category="struct" name="VkPipelineDepthStencilStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineDepthStencilStateCreateFlags</type> <name>flags</name></member>
+ <member><type>VkBool32</type> <name>depthTestEnable</name></member>
+ <member><type>VkBool32</type> <name>depthWriteEnable</name></member>
+ <member><type>VkCompareOp</type> <name>depthCompareOp</name></member>
+ <member><type>VkBool32</type> <name>depthBoundsTestEnable</name><comment>optional (depth_bounds_test)</comment></member>
+ <member><type>VkBool32</type> <name>stencilTestEnable</name></member>
+ <member><type>VkStencilOpState</type> <name>front</name></member>
+ <member><type>VkStencilOpState</type> <name>back</name></member>
+ <member><type>float</type> <name>minDepthBounds</name></member>
+ <member><type>float</type> <name>maxDepthBounds</name></member>
+ </type>
+ <type category="struct" name="VkGraphicsPipelineCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineCreateFlags</type> <name>flags</name><comment>Pipeline creation flags</comment></member>
+ <member><type>uint32_t</type> <name>stageCount</name></member>
+ <member len="stageCount">const <type>VkPipelineShaderStageCreateInfo</type>* <name>pStages</name><comment>One entry for each active shader stage</comment></member>
+ <member>const <type>VkPipelineVertexInputStateCreateInfo</type>* <name>pVertexInputState</name></member>
+ <member>const <type>VkPipelineInputAssemblyStateCreateInfo</type>* <name>pInputAssemblyState</name></member>
+ <member noautovalidity="true" optional="true">const <type>VkPipelineTessellationStateCreateInfo</type>* <name>pTessellationState</name></member>
+ <member noautovalidity="true" optional="true">const <type>VkPipelineViewportStateCreateInfo</type>* <name>pViewportState</name></member>
+ <member>const <type>VkPipelineRasterizationStateCreateInfo</type>* <name>pRasterizationState</name></member>
+ <member noautovalidity="true" optional="true">const <type>VkPipelineMultisampleStateCreateInfo</type>* <name>pMultisampleState</name></member>
+ <member noautovalidity="true" optional="true">const <type>VkPipelineDepthStencilStateCreateInfo</type>* <name>pDepthStencilState</name></member>
+ <member noautovalidity="true" optional="true">const <type>VkPipelineColorBlendStateCreateInfo</type>* <name>pColorBlendState</name></member>
+ <member optional="true">const <type>VkPipelineDynamicStateCreateInfo</type>* <name>pDynamicState</name></member>
+ <member><type>VkPipelineLayout</type> <name>layout</name><comment>Interface layout of the pipeline</comment></member>
+ <member><type>VkRenderPass</type> <name>renderPass</name></member>
+ <member><type>uint32_t</type> <name>subpass</name></member>
+ <member noautovalidity="true" optional="true"><type>VkPipeline</type> <name>basePipelineHandle</name><comment>If VK_PIPELINE_CREATE_DERIVATIVE_BIT is set and this value is nonzero, it specifies the handle of the base pipeline this is a derivative of</comment></member>
+ <member><type>int32_t</type> <name>basePipelineIndex</name><comment>If VK_PIPELINE_CREATE_DERIVATIVE_BIT is set and this value is not -1, it specifies an index into pCreateInfos of the base pipeline this is a derivative of</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineCacheCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineCacheCreateFlags</type> <name>flags</name></member>
+ <member optional="true"><type>size_t</type> <name>initialDataSize</name><comment>Size of initial data to populate cache, in bytes</comment></member>
+ <member len="initialDataSize">const <type>void</type>* <name>pInitialData</name><comment>Initial data to populate cache</comment></member>
+ </type>
+ <type category="struct" name="VkPushConstantRange">
+ <member><type>VkShaderStageFlags</type> <name>stageFlags</name><comment>Which stages use the range</comment></member>
+ <member><type>uint32_t</type> <name>offset</name><comment>Start of the range, in bytes</comment></member>
+ <member><type>uint32_t</type> <name>size</name><comment>Size of the range, in bytes</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineLayoutCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineLayoutCreateFlags</type> <name>flags</name></member>
+ <member optional="true"><type>uint32_t</type> <name>setLayoutCount</name><comment>Number of descriptor sets interfaced by the pipeline</comment></member>
+ <member len="setLayoutCount">const <type>VkDescriptorSetLayout</type>* <name>pSetLayouts</name><comment>Array of setCount number of descriptor set layout objects defining the layout of the</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>pushConstantRangeCount</name><comment>Number of push-constant ranges used by the pipeline</comment></member>
+ <member len="pushConstantRangeCount">const <type>VkPushConstantRange</type>* <name>pPushConstantRanges</name><comment>Array of pushConstantRangeCount number of ranges used by various shader stages</comment></member>
+ </type>
+ <type category="struct" name="VkSamplerCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkSamplerCreateFlags</type> <name>flags</name></member>
+ <member><type>VkFilter</type> <name>magFilter</name><comment>Filter mode for magnification</comment></member>
+ <member><type>VkFilter</type> <name>minFilter</name><comment>Filter mode for minifiation</comment></member>
+ <member><type>VkSamplerMipmapMode</type> <name>mipmapMode</name><comment>Mipmap selection mode</comment></member>
+ <member><type>VkSamplerAddressMode</type> <name>addressModeU</name></member>
+ <member><type>VkSamplerAddressMode</type> <name>addressModeV</name></member>
+ <member><type>VkSamplerAddressMode</type> <name>addressModeW</name></member>
+ <member><type>float</type> <name>mipLodBias</name></member>
+ <member><type>VkBool32</type> <name>anisotropyEnable</name></member>
+ <member><type>float</type> <name>maxAnisotropy</name></member>
+ <member><type>VkBool32</type> <name>compareEnable</name></member>
+ <member noautovalidity="true"><type>VkCompareOp</type> <name>compareOp</name></member>
+ <member><type>float</type> <name>minLod</name></member>
+ <member><type>float</type> <name>maxLod</name></member>
+ <member noautovalidity="true"><type>VkBorderColor</type> <name>borderColor</name></member>
+ <member><type>VkBool32</type> <name>unnormalizedCoordinates</name></member>
+ </type>
+ <type category="struct" name="VkCommandPoolCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkCommandPoolCreateFlags</type> <name>flags</name><comment>Command pool creation flags</comment></member>
+ <member><type>uint32_t</type> <name>queueFamilyIndex</name></member>
+ </type>
+ <type category="struct" name="VkCommandBufferAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkCommandPool</type> <name>commandPool</name></member>
+ <member><type>VkCommandBufferLevel</type> <name>level</name></member>
+ <member><type>uint32_t</type> <name>commandBufferCount</name></member>
+ </type>
+ <type category="struct" name="VkCommandBufferInheritanceInfo">
+ <member values="VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true" noautovalidity="true"><type>VkRenderPass</type> <name>renderPass</name><comment>Render pass for secondary command buffers</comment></member>
+ <member><type>uint32_t</type> <name>subpass</name></member>
+ <member optional="true" noautovalidity="true"><type>VkFramebuffer</type> <name>framebuffer</name><comment>Framebuffer for secondary command buffers</comment></member>
+ <member><type>VkBool32</type> <name>occlusionQueryEnable</name><comment>Whether this secondary command buffer may be executed during an occlusion query</comment></member>
+ <member optional="true" noautovalidity="true"><type>VkQueryControlFlags</type> <name>queryFlags</name><comment>Query flags used by this secondary command buffer, if executed during an occlusion query</comment></member>
+ <member optional="true" noautovalidity="true"><type>VkQueryPipelineStatisticFlags</type> <name>pipelineStatistics</name><comment>Pipeline statistics that may be counted for this secondary command buffer</comment></member>
+ </type>
+ <type category="struct" name="VkCommandBufferBeginInfo">
+ <member values="VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkCommandBufferUsageFlags</type> <name>flags</name><comment>Command buffer usage flags</comment></member>
+ <member optional="true" noautovalidity="true">const <type>VkCommandBufferInheritanceInfo</type>* <name>pInheritanceInfo</name><comment>Pointer to inheritance info for secondary command buffers</comment></member>
+ </type>
+ <type category="struct" name="VkRenderPassBeginInfo">
+ <member values="VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkRenderPass</type> <name>renderPass</name></member>
+ <member><type>VkFramebuffer</type> <name>framebuffer</name></member>
+ <member><type>VkRect2D</type> <name>renderArea</name></member>
+ <member optional="true"><type>uint32_t</type> <name>clearValueCount</name></member>
+ <member len="clearValueCount" noautovalidity="true">const <type>VkClearValue</type>* <name>pClearValues</name></member>
+ </type>
+ <type category="union" name="VkClearColorValue" comment="// Union allowing specification of floating point, integer, or unsigned integer color data. Actual value selected is based on image/attachment being cleared.">
+ <member><type>float</type> <name>float32</name>[4]</member>
+ <member><type>int32_t</type> <name>int32</name>[4]</member>
+ <member><type>uint32_t</type> <name>uint32</name>[4]</member>
+ </type>
+ <type category="struct" name="VkClearDepthStencilValue">
+ <member><type>float</type> <name>depth</name></member>
+ <member><type>uint32_t</type> <name>stencil</name></member>
+ </type>
+ <type category="union" name="VkClearValue" comment="// Union allowing specification of color or depth and stencil values. Actual value selected is based on attachment being cleared.">
+ <member><type>VkClearColorValue</type> <name>color</name></member>
+ <member><type>VkClearDepthStencilValue</type> <name>depthStencil</name></member>
+ </type>
+ <type category="struct" name="VkClearAttachment">
+ <member><type>VkImageAspectFlags</type> <name>aspectMask</name></member>
+ <member><type>uint32_t</type> <name>colorAttachment</name></member>
+ <member><type>VkClearValue</type> <name>clearValue</name></member>
+ </type>
+ <type category="struct" name="VkAttachmentDescription">
+ <member optional="true"><type>VkAttachmentDescriptionFlags</type> <name>flags</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>VkSampleCountFlagBits</type> <name>samples</name></member>
+ <member><type>VkAttachmentLoadOp</type> <name>loadOp</name><comment>Load operation for color or depth data</comment></member>
+ <member><type>VkAttachmentStoreOp</type> <name>storeOp</name><comment>Store operation for color or depth data</comment></member>
+ <member><type>VkAttachmentLoadOp</type> <name>stencilLoadOp</name><comment>Load operation for stencil data</comment></member>
+ <member><type>VkAttachmentStoreOp</type> <name>stencilStoreOp</name><comment>Store operation for stencil data</comment></member>
+ <member><type>VkImageLayout</type> <name>initialLayout</name></member>
+ <member><type>VkImageLayout</type> <name>finalLayout</name></member>
+ </type>
+ <type category="struct" name="VkAttachmentReference">
+ <member><type>uint32_t</type> <name>attachment</name></member>
+ <member><type>VkImageLayout</type> <name>layout</name></member>
+ </type>
+ <type category="struct" name="VkSubpassDescription">
+ <member optional="true"><type>VkSubpassDescriptionFlags</type> <name>flags</name></member>
+ <member><type>VkPipelineBindPoint</type> <name>pipelineBindPoint</name><comment>Must be VK_PIPELINE_BIND_POINT_GRAPHICS for now</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>inputAttachmentCount</name></member>
+ <member len="inputAttachmentCount">const <type>VkAttachmentReference</type>* <name>pInputAttachments</name></member>
+ <member optional="true"><type>uint32_t</type> <name>colorAttachmentCount</name></member>
+ <member len="colorAttachmentCount">const <type>VkAttachmentReference</type>* <name>pColorAttachments</name></member>
+ <member optional="true" len="colorAttachmentCount">const <type>VkAttachmentReference</type>* <name>pResolveAttachments</name></member>
+ <member optional="true">const <type>VkAttachmentReference</type>* <name>pDepthStencilAttachment</name></member>
+ <member optional="true"><type>uint32_t</type> <name>preserveAttachmentCount</name></member>
+ <member len="preserveAttachmentCount">const <type>uint32_t</type>* <name>pPreserveAttachments</name></member>
+ </type>
+ <type category="struct" name="VkSubpassDependency">
+ <member><type>uint32_t</type> <name>srcSubpass</name></member>
+ <member><type>uint32_t</type> <name>dstSubpass</name></member>
+ <member><type>VkPipelineStageFlags</type> <name>srcStageMask</name></member>
+ <member><type>VkPipelineStageFlags</type> <name>dstStageMask</name></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>srcAccessMask</name><comment>Memory accesses from the source of the dependency to synchronize</comment></member>
+ <member optional="true"><type>VkAccessFlags</type> <name>dstAccessMask</name><comment>Memory accesses from the destination of the dependency to synchronize</comment></member>
+ <member optional="true"><type>VkDependencyFlags</type> <name>dependencyFlags</name></member>
+ </type>
+ <type category="struct" name="VkRenderPassCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkRenderPassCreateFlags</type> <name>flags</name></member>
+ <member optional="true"><type>uint32_t</type> <name>attachmentCount</name></member>
+ <member len="attachmentCount">const <type>VkAttachmentDescription</type>* <name>pAttachments</name></member>
+ <member><type>uint32_t</type> <name>subpassCount</name></member>
+ <member len="subpassCount">const <type>VkSubpassDescription</type>* <name>pSubpasses</name></member>
+ <member optional="true"><type>uint32_t</type> <name>dependencyCount</name></member>
+ <member len="dependencyCount">const <type>VkSubpassDependency</type>* <name>pDependencies</name></member>
+ </type>
+ <type category="struct" name="VkEventCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EVENT_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkEventCreateFlags</type> <name>flags</name><comment>Event creation flags</comment></member>
+ </type>
+ <type category="struct" name="VkFenceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_FENCE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkFenceCreateFlags</type> <name>flags</name><comment>Fence creation flags</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceFeatures">
+ <member><type>VkBool32</type> <name>robustBufferAccess</name><comment>out of bounds buffer accesses are well defined</comment></member>
+ <member><type>VkBool32</type> <name>fullDrawIndexUint32</name><comment>full 32-bit range of indices for indexed draw calls</comment></member>
+ <member><type>VkBool32</type> <name>imageCubeArray</name><comment>image views which are arrays of cube maps</comment></member>
+ <member><type>VkBool32</type> <name>independentBlend</name><comment>blending operations are controlled per-attachment</comment></member>
+ <member><type>VkBool32</type> <name>geometryShader</name><comment>geometry stage</comment></member>
+ <member><type>VkBool32</type> <name>tessellationShader</name><comment>tessellation control and evaluation stage</comment></member>
+ <member><type>VkBool32</type> <name>sampleRateShading</name><comment>per-sample shading and interpolation</comment></member>
+ <member><type>VkBool32</type> <name>dualSrcBlend</name><comment>blend operations which take two sources</comment></member>
+ <member><type>VkBool32</type> <name>logicOp</name><comment>logic operations</comment></member>
+ <member><type>VkBool32</type> <name>multiDrawIndirect</name><comment>multi draw indirect</comment></member>
+ <member><type>VkBool32</type> <name>drawIndirectFirstInstance</name><comment>indirect draws can use non-zero firstInstance</comment></member>
+ <member><type>VkBool32</type> <name>depthClamp</name><comment>depth clamping</comment></member>
+ <member><type>VkBool32</type> <name>depthBiasClamp</name><comment>depth bias clamping</comment></member>
+ <member><type>VkBool32</type> <name>fillModeNonSolid</name><comment>point and wireframe fill modes</comment></member>
+ <member><type>VkBool32</type> <name>depthBounds</name><comment>depth bounds test</comment></member>
+ <member><type>VkBool32</type> <name>wideLines</name><comment>lines with width greater than 1</comment></member>
+ <member><type>VkBool32</type> <name>largePoints</name><comment>points with size greater than 1</comment></member>
+ <member><type>VkBool32</type> <name>alphaToOne</name><comment>the fragment alpha component can be forced to maximum representable alpha value</comment></member>
+ <member><type>VkBool32</type> <name>multiViewport</name><comment>viewport arrays</comment></member>
+ <member><type>VkBool32</type> <name>samplerAnisotropy</name><comment>anisotropic sampler filtering</comment></member>
+ <member><type>VkBool32</type> <name>textureCompressionETC2</name><comment>ETC texture compression formats</comment></member>
+ <member><type>VkBool32</type> <name>textureCompressionASTC_LDR</name><comment>ASTC LDR texture compression formats</comment></member>
+ <member><type>VkBool32</type> <name>textureCompressionBC</name><comment>BC1-7 texture compressed formats</comment></member>
+ <member><type>VkBool32</type> <name>occlusionQueryPrecise</name><comment>precise occlusion queries returning actual sample counts</comment></member>
+ <member><type>VkBool32</type> <name>pipelineStatisticsQuery</name><comment>pipeline statistics query</comment></member>
+ <member><type>VkBool32</type> <name>vertexPipelineStoresAndAtomics</name><comment>stores and atomic ops on storage buffers and images are supported in vertex, tessellation, and geometry stages</comment></member>
+ <member><type>VkBool32</type> <name>fragmentStoresAndAtomics</name><comment>stores and atomic ops on storage buffers and images are supported in the fragment stage</comment></member>
+ <member><type>VkBool32</type> <name>shaderTessellationAndGeometryPointSize</name><comment>tessellation and geometry stages can export point size</comment></member>
+ <member><type>VkBool32</type> <name>shaderImageGatherExtended</name><comment>image gather with run-time values and independent offsets</comment></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageExtendedFormats</name><comment>the extended set of formats can be used for storage images</comment></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageMultisample</name><comment>multisample images can be used for storage images</comment></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageReadWithoutFormat</name><comment>read from storage image does not require format qualifier</comment></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageWriteWithoutFormat</name><comment>write to storage image does not require format qualifier</comment></member>
+ <member><type>VkBool32</type> <name>shaderUniformBufferArrayDynamicIndexing</name><comment>arrays of uniform buffers can be accessed with dynamically uniform indices</comment></member>
+ <member><type>VkBool32</type> <name>shaderSampledImageArrayDynamicIndexing</name><comment>arrays of sampled images can be accessed with dynamically uniform indices</comment></member>
+ <member><type>VkBool32</type> <name>shaderStorageBufferArrayDynamicIndexing</name><comment>arrays of storage buffers can be accessed with dynamically uniform indices</comment></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageArrayDynamicIndexing</name><comment>arrays of storage images can be accessed with dynamically uniform indices</comment></member>
+ <member><type>VkBool32</type> <name>shaderClipDistance</name><comment>clip distance in shaders</comment></member>
+ <member><type>VkBool32</type> <name>shaderCullDistance</name><comment>cull distance in shaders</comment></member>
+ <member><type>VkBool32</type> <name>shaderFloat64</name><comment>64-bit floats (doubles) in shaders</comment></member>
+ <member><type>VkBool32</type> <name>shaderInt64</name><comment>64-bit integers in shaders</comment></member>
+ <member><type>VkBool32</type> <name>shaderInt16</name><comment>16-bit integers in shaders</comment></member>
+ <member><type>VkBool32</type> <name>shaderResourceResidency</name><comment>shader can use texture operations that return resource residency information (requires sparseNonResident support)</comment></member>
+ <member><type>VkBool32</type> <name>shaderResourceMinLod</name><comment>shader can use texture operations that specify minimum resource LOD</comment></member>
+ <member><type>VkBool32</type> <name>sparseBinding</name><comment>Sparse resources support: Resource memory can be managed at opaque page level rather than object level</comment></member>
+ <member><type>VkBool32</type> <name>sparseResidencyBuffer</name><comment>Sparse resources support: GPU can access partially resident buffers </comment></member>
+ <member><type>VkBool32</type> <name>sparseResidencyImage2D</name><comment>Sparse resources support: GPU can access partially resident 2D (non-MSAA non-depth/stencil) images </comment></member>
+ <member><type>VkBool32</type> <name>sparseResidencyImage3D</name><comment>Sparse resources support: GPU can access partially resident 3D images </comment></member>
+ <member><type>VkBool32</type> <name>sparseResidency2Samples</name><comment>Sparse resources support: GPU can access partially resident MSAA 2D images with 2 samples</comment></member>
+ <member><type>VkBool32</type> <name>sparseResidency4Samples</name><comment>Sparse resources support: GPU can access partially resident MSAA 2D images with 4 samples</comment></member>
+ <member><type>VkBool32</type> <name>sparseResidency8Samples</name><comment>Sparse resources support: GPU can access partially resident MSAA 2D images with 8 samples</comment></member>
+ <member><type>VkBool32</type> <name>sparseResidency16Samples</name><comment>Sparse resources support: GPU can access partially resident MSAA 2D images with 16 samples</comment></member>
+ <member><type>VkBool32</type> <name>sparseResidencyAliased</name><comment>Sparse resources support: GPU can correctly access data aliased into multiple locations (opt-in)</comment></member>
+ <member><type>VkBool32</type> <name>variableMultisampleRate</name><comment>multisample rate must be the same for all pipelines in a subpass</comment></member>
+ <member><type>VkBool32</type> <name>inheritedQueries</name><comment>Queries may be inherited from primary to secondary command buffers</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceSparseProperties" returnedonly="true">
+ <member><type>VkBool32</type> <name>residencyStandard2DBlockShape</name><comment>Sparse resources support: GPU will access all 2D (single sample) sparse resources using the standard sparse image block shapes (based on pixel format)</comment></member>
+ <member><type>VkBool32</type> <name>residencyStandard2DMultisampleBlockShape</name><comment>Sparse resources support: GPU will access all 2D (multisample) sparse resources using the standard sparse image block shapes (based on pixel format)</comment></member>
+ <member><type>VkBool32</type> <name>residencyStandard3DBlockShape</name><comment>Sparse resources support: GPU will access all 3D sparse resources using the standard sparse image block shapes (based on pixel format)</comment></member>
+ <member><type>VkBool32</type> <name>residencyAlignedMipSize</name><comment>Sparse resources support: Images with mip level dimensions that are NOT a multiple of the sparse image block dimensions will be placed in the mip tail</comment></member>
+ <member><type>VkBool32</type> <name>residencyNonResidentStrict</name><comment>Sparse resources support: GPU can consistently access non-resident regions of a resource, all reads return as if data is 0, writes are discarded</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceLimits" returnedonly="true">
+ <comment>resource maximum sizes</comment>
+ <member><type>uint32_t</type> <name>maxImageDimension1D</name><comment>max 1D image dimension</comment></member>
+ <member><type>uint32_t</type> <name>maxImageDimension2D</name><comment>max 2D image dimension</comment></member>
+ <member><type>uint32_t</type> <name>maxImageDimension3D</name><comment>max 3D image dimension</comment></member>
+ <member><type>uint32_t</type> <name>maxImageDimensionCube</name><comment>max cubemap image dimension</comment></member>
+ <member><type>uint32_t</type> <name>maxImageArrayLayers</name><comment>max layers for image arrays</comment></member>
+ <member><type>uint32_t</type> <name>maxTexelBufferElements</name><comment>max texel buffer size (fstexels)</comment></member>
+ <member><type>uint32_t</type> <name>maxUniformBufferRange</name><comment>max uniform buffer range (bytes)</comment></member>
+ <member><type>uint32_t</type> <name>maxStorageBufferRange</name><comment>max storage buffer range (bytes)</comment></member>
+ <member><type>uint32_t</type> <name>maxPushConstantsSize</name><comment>max size of the push constants pool (bytes)</comment></member>
+ <comment>memory limits</comment>
+ <member><type>uint32_t</type> <name>maxMemoryAllocationCount</name><comment>max number of device memory allocations supported</comment></member>
+ <member><type>uint32_t</type> <name>maxSamplerAllocationCount</name><comment>max number of samplers that can be allocated on a device</comment></member>
+ <member><type>VkDeviceSize</type> <name>bufferImageGranularity</name><comment>Granularity (in bytes) at which buffers and images can be bound to adjacent memory for simultaneous usage</comment></member>
+ <member><type>VkDeviceSize</type> <name>sparseAddressSpaceSize</name><comment>Total address space available for sparse allocations (bytes)</comment></member>
+ <comment>descriptor set limits</comment>
+ <member><type>uint32_t</type> <name>maxBoundDescriptorSets</name><comment>max number of descriptors sets that can be bound to a pipeline</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorSamplers</name><comment>max number of samplers allowed per-stage in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUniformBuffers</name><comment>max number of uniform buffers allowed per-stage in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorStorageBuffers</name><comment>max number of storage buffers allowed per-stage in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorSampledImages</name><comment>max number of sampled images allowed per-stage in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorStorageImages</name><comment>max number of storage images allowed per-stage in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorInputAttachments</name><comment>max number of input attachments allowed per-stage in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxPerStageResources</name><comment>max number of resources allowed by a single stage</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetSamplers</name><comment>max number of samplers allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUniformBuffers</name><comment>max number of uniform buffers allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUniformBuffersDynamic</name><comment>max number of dynamic uniform buffers allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetStorageBuffers</name><comment>max number of storage buffers allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetStorageBuffersDynamic</name><comment>max number of dynamic storage buffers allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetSampledImages</name><comment>max number of sampled images allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetStorageImages</name><comment>max number of storage images allowed in all stages in a descriptor set</comment></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetInputAttachments</name><comment>max number of input attachments allowed in all stages in a descriptor set</comment></member>
+ <comment>vertex stage limits</comment>
+ <member><type>uint32_t</type> <name>maxVertexInputAttributes</name><comment>max number of vertex input attribute slots</comment></member>
+ <member><type>uint32_t</type> <name>maxVertexInputBindings</name><comment>max number of vertex input binding slots</comment></member>
+ <member><type>uint32_t</type> <name>maxVertexInputAttributeOffset</name><comment>max vertex input attribute offset added to vertex buffer offset</comment></member>
+ <member><type>uint32_t</type> <name>maxVertexInputBindingStride</name><comment>max vertex input binding stride</comment></member>
+ <member><type>uint32_t</type> <name>maxVertexOutputComponents</name><comment>max number of output components written by vertex shader</comment></member>
+ <comment>tessellation control stage limits</comment>
+ <member><type>uint32_t</type> <name>maxTessellationGenerationLevel</name><comment>max level supported by tessellation primitive generator</comment></member>
+ <member><type>uint32_t</type> <name>maxTessellationPatchSize</name><comment>max patch size (vertices)</comment></member>
+ <member><type>uint32_t</type> <name>maxTessellationControlPerVertexInputComponents</name><comment>max number of input components per-vertex in TCS</comment></member>
+ <member><type>uint32_t</type> <name>maxTessellationControlPerVertexOutputComponents</name><comment>max number of output components per-vertex in TCS</comment></member>
+ <member><type>uint32_t</type> <name>maxTessellationControlPerPatchOutputComponents</name><comment>max number of output components per-patch in TCS</comment></member>
+ <member><type>uint32_t</type> <name>maxTessellationControlTotalOutputComponents</name><comment>max total number of per-vertex and per-patch output components in TCS</comment></member>
+ <comment>tessellation evaluation stage limits</comment>
+ <member><type>uint32_t</type> <name>maxTessellationEvaluationInputComponents</name><comment>max number of input components per vertex in TES</comment></member>
+ <member><type>uint32_t</type> <name>maxTessellationEvaluationOutputComponents</name><comment>max number of output components per vertex in TES</comment></member>
+ <comment>geometry stage limits</comment>
+ <member><type>uint32_t</type> <name>maxGeometryShaderInvocations</name><comment>max invocation count supported in geometry shader</comment></member>
+ <member><type>uint32_t</type> <name>maxGeometryInputComponents</name><comment>max number of input components read in geometry stage</comment></member>
+ <member><type>uint32_t</type> <name>maxGeometryOutputComponents</name><comment>max number of output components written in geometry stage</comment></member>
+ <member><type>uint32_t</type> <name>maxGeometryOutputVertices</name><comment>max number of vertices that can be emitted in geometry stage</comment></member>
+ <member><type>uint32_t</type> <name>maxGeometryTotalOutputComponents</name><comment>max total number of components (all vertices) written in geometry stage</comment></member>
+ <comment>fragment stage limits</comment>
+ <member><type>uint32_t</type> <name>maxFragmentInputComponents</name><comment>max number of input components read in fragment stage</comment></member>
+ <member><type>uint32_t</type> <name>maxFragmentOutputAttachments</name><comment>max number of output attachments written in fragment stage</comment></member>
+ <member><type>uint32_t</type> <name>maxFragmentDualSrcAttachments</name><comment>max number of output attachments written when using dual source blending</comment></member>
+ <member><type>uint32_t</type> <name>maxFragmentCombinedOutputResources</name><comment>max total number of storage buffers, storage images and output buffers</comment></member>
+ <comment>compute stage limits</comment>
+ <member><type>uint32_t</type> <name>maxComputeSharedMemorySize</name><comment>max total storage size of work group local storage (bytes)</comment></member>
+ <member><type>uint32_t</type> <name>maxComputeWorkGroupCount</name>[3]<comment>max num of compute work groups that may be dispatched by a single command (x,y,z)</comment></member>
+ <member><type>uint32_t</type> <name>maxComputeWorkGroupInvocations</name><comment>max total compute invocations in a single local work group</comment></member>
+ <member><type>uint32_t</type> <name>maxComputeWorkGroupSize</name>[3]<comment>max local size of a compute work group (x,y,z)</comment></member>
+ <member><type>uint32_t</type> <name>subPixelPrecisionBits</name><comment>number bits of subpixel precision in screen x and y</comment></member>
+ <member><type>uint32_t</type> <name>subTexelPrecisionBits</name><comment>number bits of precision for selecting texel weights</comment></member>
+ <member><type>uint32_t</type> <name>mipmapPrecisionBits</name><comment>number bits of precision for selecting mipmap weights</comment></member>
+ <member><type>uint32_t</type> <name>maxDrawIndexedIndexValue</name><comment>max index value for indexed draw calls (for 32-bit indices)</comment></member>
+ <member><type>uint32_t</type> <name>maxDrawIndirectCount</name><comment>max draw count for indirect draw calls</comment></member>
+ <member><type>float</type> <name>maxSamplerLodBias</name><comment>max absolute sampler LOD bias</comment></member>
+ <member><type>float</type> <name>maxSamplerAnisotropy</name><comment>max degree of sampler anisotropy</comment></member>
+ <member><type>uint32_t</type> <name>maxViewports</name><comment>max number of active viewports</comment></member>
+ <member><type>uint32_t</type> <name>maxViewportDimensions</name>[2]<comment>max viewport dimensions (x,y)</comment></member>
+ <member><type>float</type> <name>viewportBoundsRange</name>[2]<comment>viewport bounds range (min,max)</comment></member>
+ <member><type>uint32_t</type> <name>viewportSubPixelBits</name><comment>number bits of subpixel precision for viewport</comment></member>
+ <member><type>size_t</type> <name>minMemoryMapAlignment</name><comment>min required alignment of pointers returned by MapMemory (bytes)</comment></member>
+ <member><type>VkDeviceSize</type> <name>minTexelBufferOffsetAlignment</name><comment>min required alignment for texel buffer offsets (bytes) </comment></member>
+ <member><type>VkDeviceSize</type> <name>minUniformBufferOffsetAlignment</name><comment>min required alignment for uniform buffer sizes and offsets (bytes)</comment></member>
+ <member><type>VkDeviceSize</type> <name>minStorageBufferOffsetAlignment</name><comment>min required alignment for storage buffer offsets (bytes)</comment></member>
+ <member><type>int32_t</type> <name>minTexelOffset</name><comment>min texel offset for OpTextureSampleOffset</comment></member>
+ <member><type>uint32_t</type> <name>maxTexelOffset</name><comment>max texel offset for OpTextureSampleOffset</comment></member>
+ <member><type>int32_t</type> <name>minTexelGatherOffset</name><comment>min texel offset for OpTextureGatherOffset</comment></member>
+ <member><type>uint32_t</type> <name>maxTexelGatherOffset</name><comment>max texel offset for OpTextureGatherOffset</comment></member>
+ <member><type>float</type> <name>minInterpolationOffset</name><comment>furthest negative offset for interpolateAtOffset</comment></member>
+ <member><type>float</type> <name>maxInterpolationOffset</name><comment>furthest positive offset for interpolateAtOffset</comment></member>
+ <member><type>uint32_t</type> <name>subPixelInterpolationOffsetBits</name><comment>number of subpixel bits for interpolateAtOffset</comment></member>
+ <member><type>uint32_t</type> <name>maxFramebufferWidth</name><comment>max width for a framebuffer</comment></member>
+ <member><type>uint32_t</type> <name>maxFramebufferHeight</name><comment>max height for a framebuffer</comment></member>
+ <member><type>uint32_t</type> <name>maxFramebufferLayers</name><comment>max layer count for a layered framebuffer</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>framebufferColorSampleCounts</name><comment>supported color sample counts for a framebuffer</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>framebufferDepthSampleCounts</name><comment>supported depth sample counts for a framebuffer</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>framebufferStencilSampleCounts</name><comment>supported stencil sample counts for a framebuffer</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>framebufferNoAttachmentsSampleCounts</name><comment>supported sample counts for a framebuffer with no attachments</comment></member>
+ <member><type>uint32_t</type> <name>maxColorAttachments</name><comment>max number of color attachments per subpass</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>sampledImageColorSampleCounts</name><comment>supported color sample counts for a non-integer sampled image</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>sampledImageIntegerSampleCounts</name><comment>supported sample counts for an integer image</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>sampledImageDepthSampleCounts</name><comment>supported depth sample counts for a sampled image</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>sampledImageStencilSampleCounts</name><comment>supported stencil sample counts for a sampled image</comment></member>
+ <member optional="true"><type>VkSampleCountFlags</type> <name>storageImageSampleCounts</name><comment>supported sample counts for a storage image</comment></member>
+ <member><type>uint32_t</type> <name>maxSampleMaskWords</name><comment>max number of sample mask words</comment></member>
+ <member><type>VkBool32</type> <name>timestampComputeAndGraphics</name><comment>timestamps on graphics and compute queues</comment></member>
+ <member><type>float</type> <name>timestampPeriod</name><comment>number of nanoseconds it takes for timestamp query value to increment by 1</comment></member>
+ <member><type>uint32_t</type> <name>maxClipDistances</name><comment>max number of clip distances</comment></member>
+ <member><type>uint32_t</type> <name>maxCullDistances</name><comment>max number of cull distances</comment></member>
+ <member><type>uint32_t</type> <name>maxCombinedClipAndCullDistances</name><comment>max combined number of user clipping</comment></member>
+ <member><type>uint32_t</type> <name>discreteQueuePriorities</name><comment>distinct queue priorities available </comment></member>
+ <member><type>float</type> <name>pointSizeRange</name>[2]<comment>range (min,max) of supported point sizes</comment></member>
+ <member><type>float</type> <name>lineWidthRange</name>[2]<comment>range (min,max) of supported line widths</comment></member>
+ <member><type>float</type> <name>pointSizeGranularity</name><comment>granularity of supported point sizes</comment></member>
+ <member><type>float</type> <name>lineWidthGranularity</name><comment>granularity of supported line widths</comment></member>
+ <member><type>VkBool32</type> <name>strictLines</name><comment>line rasterization follows preferred rules</comment></member>
+ <member><type>VkBool32</type> <name>standardSampleLocations</name><comment>supports standard sample locations for all supported sample counts</comment></member>
+ <member><type>VkDeviceSize</type> <name>optimalBufferCopyOffsetAlignment</name><comment>optimal offset of buffer copies</comment></member>
+ <member><type>VkDeviceSize</type> <name>optimalBufferCopyRowPitchAlignment</name><comment>optimal pitch of buffer copies</comment></member>
+ <member><type>VkDeviceSize</type> <name>nonCoherentAtomSize</name><comment>minimum size and alignment for non-coherent host-mapped device memory access</comment></member>
+ </type>
+ <type category="struct" name="VkSemaphoreCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkSemaphoreCreateFlags</type> <name>flags</name><comment>Semaphore creation flags</comment></member>
+ </type>
+ <type category="struct" name="VkQueryPoolCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkQueryPoolCreateFlags</type> <name>flags</name></member>
+ <member><type>VkQueryType</type> <name>queryType</name></member>
+ <member><type>uint32_t</type> <name>queryCount</name></member>
+ <member optional="true" noautovalidity="true"><type>VkQueryPipelineStatisticFlags</type> <name>pipelineStatistics</name><comment>Optional</comment></member>
+ </type>
+ <type category="struct" name="VkFramebufferCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkFramebufferCreateFlags</type> <name>flags</name></member>
+ <member><type>VkRenderPass</type> <name>renderPass</name></member>
+ <member optional="true"><type>uint32_t</type> <name>attachmentCount</name></member>
+ <member len="attachmentCount">const <type>VkImageView</type>* <name>pAttachments</name></member>
+ <member><type>uint32_t</type> <name>width</name></member>
+ <member><type>uint32_t</type> <name>height</name></member>
+ <member><type>uint32_t</type> <name>layers</name></member>
+ </type>
+ <type category="struct" name="VkDrawIndirectCommand">
+ <member><type>uint32_t</type> <name>vertexCount</name></member>
+ <member><type>uint32_t</type> <name>instanceCount</name></member>
+ <member><type>uint32_t</type> <name>firstVertex</name></member>
+ <member><type>uint32_t</type> <name>firstInstance</name></member>
+ </type>
+ <type category="struct" name="VkDrawIndexedIndirectCommand">
+ <member><type>uint32_t</type> <name>indexCount</name></member>
+ <member><type>uint32_t</type> <name>instanceCount</name></member>
+ <member><type>uint32_t</type> <name>firstIndex</name></member>
+ <member><type>int32_t</type> <name>vertexOffset</name></member>
+ <member><type>uint32_t</type> <name>firstInstance</name></member>
+ </type>
+ <type category="struct" name="VkDispatchIndirectCommand">
+ <member><type>uint32_t</type> <name>x</name></member>
+ <member><type>uint32_t</type> <name>y</name></member>
+ <member><type>uint32_t</type> <name>z</name></member>
+ </type>
+ <type category="struct" name="VkSubmitInfo">
+ <member values="VK_STRUCTURE_TYPE_SUBMIT_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>waitSemaphoreCount</name></member>
+ <member len="waitSemaphoreCount">const <type>VkSemaphore</type>* <name>pWaitSemaphores</name></member>
+ <member len="waitSemaphoreCount">const <type>VkPipelineStageFlags</type>* <name>pWaitDstStageMask</name></member>
+ <member optional="true"><type>uint32_t</type> <name>commandBufferCount</name></member>
+ <member len="commandBufferCount">const <type>VkCommandBuffer</type>* <name>pCommandBuffers</name></member>
+ <member optional="true"><type>uint32_t</type> <name>signalSemaphoreCount</name></member>
+ <member len="signalSemaphoreCount">const <type>VkSemaphore</type>* <name>pSignalSemaphores</name></member>
+ </type>
+ <comment>WSI extensions</comment>
+ <type category="struct" name="VkDisplayPropertiesKHR" returnedonly="true">
+ <member><type>VkDisplayKHR</type> <name>display</name><comment>Handle of the display object</comment></member>
+ <member len="null-terminated">const <type>char</type>* <name>displayName</name><comment>Name of the display</comment></member>
+ <member><type>VkExtent2D</type> <name>physicalDimensions</name><comment>In millimeters?</comment></member>
+ <member><type>VkExtent2D</type> <name>physicalResolution</name><comment>Max resolution for CRT?</comment></member>
+ <member optional="true"><type>VkSurfaceTransformFlagsKHR</type> <name>supportedTransforms</name><comment>one or more bits from VkSurfaceTransformFlagsKHR</comment></member>
+ <member><type>VkBool32</type> <name>planeReorderPossible</name><comment>VK_TRUE if the overlay plane's z-order can be changed on this display.</comment></member>
+ <member><type>VkBool32</type> <name>persistentContent</name><comment>VK_TRUE if this is a "smart" display that supports self-refresh/internal buffering.</comment></member>
+ </type>
+ <type category="struct" name="VkDisplayPlanePropertiesKHR" returnedonly="true">
+ <member><type>VkDisplayKHR</type> <name>currentDisplay</name><comment>Display the plane is currently associated with. Will be VK_NULL_HANDLE if the plane is not in use.</comment></member>
+ <member><type>uint32_t</type> <name>currentStackIndex</name><comment>Current z-order of the plane.</comment></member>
+ </type>
+ <type category="struct" name="VkDisplayModeParametersKHR">
+ <member><type>VkExtent2D</type> <name>visibleRegion</name><comment>Visible scanout region.</comment></member>
+ <member><type>uint32_t</type> <name>refreshRate</name><comment>Number of times per second the display is updated.</comment></member>
+ </type>
+ <type category="struct" name="VkDisplayModePropertiesKHR" returnedonly="true">
+ <member><type>VkDisplayModeKHR</type> <name>displayMode</name><comment>Handle of this display mode.</comment></member>
+ <member><type>VkDisplayModeParametersKHR</type> <name>parameters</name><comment>The parameters this mode uses.</comment></member>
+ </type>
+ <type category="struct" name="VkDisplayModeCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDisplayModeCreateFlagsKHR</type> <name>flags</name></member>
+ <member><type>VkDisplayModeParametersKHR</type> <name>parameters</name><comment>The parameters this mode uses.</comment></member>
+ </type>
+ <type category="struct" name="VkDisplayPlaneCapabilitiesKHR" returnedonly="true">
+ <member optional="true"><type>VkDisplayPlaneAlphaFlagsKHR</type> <name>supportedAlpha</name><comment>Types of alpha blending supported, if any.</comment></member>
+ <member><type>VkOffset2D</type> <name>minSrcPosition</name><comment>Does the plane have any position and extent restrictions?</comment></member>
+ <member><type>VkOffset2D</type> <name>maxSrcPosition</name></member>
+ <member><type>VkExtent2D</type> <name>minSrcExtent</name></member>
+ <member><type>VkExtent2D</type> <name>maxSrcExtent</name></member>
+ <member><type>VkOffset2D</type> <name>minDstPosition</name></member>
+ <member><type>VkOffset2D</type> <name>maxDstPosition</name></member>
+ <member><type>VkExtent2D</type> <name>minDstExtent</name></member>
+ <member><type>VkExtent2D</type> <name>maxDstExtent</name></member>
+ </type>
+ <type category="struct" name="VkDisplaySurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDisplaySurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member><type>VkDisplayModeKHR</type> <name>displayMode</name><comment>The mode to use when displaying this surface</comment></member>
+ <member><type>uint32_t</type> <name>planeIndex</name><comment>The plane on which this surface appears. Must be between 0 and the value returned by vkGetPhysicalDeviceDisplayPlanePropertiesKHR() in pPropertyCount.</comment></member>
+ <member><type>uint32_t</type> <name>planeStackIndex</name><comment>The z-order of the plane.</comment></member>
+ <member><type>VkSurfaceTransformFlagBitsKHR</type> <name>transform</name><comment>Transform to apply to the images as part of the scanout operation</comment></member>
+ <member><type>float</type> <name>globalAlpha</name><comment>Global alpha value. Must be between 0 and 1, inclusive. Ignored if alphaMode is not VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR</comment></member>
+ <member><type>VkDisplayPlaneAlphaFlagBitsKHR</type> <name>alphaMode</name><comment>What type of alpha blending to use. Must be a bit from vkGetDisplayPlanePropertiesKHR::supportedAlpha.</comment></member>
+ <member><type>VkExtent2D</type> <name>imageExtent</name><comment>size of the images to use with this surface</comment></member>
+ </type>
+ <type category="struct" name="VkDisplayPresentInfoKHR" structextends="VkPresentInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkRect2D</type> <name>srcRect</name><comment>Rectangle within the presentable image to read pixel data from when presenting to the display.</comment></member>
+ <member><type>VkRect2D</type> <name>dstRect</name><comment>Rectangle within the current display mode's visible region to display srcRectangle in.</comment></member>
+ <member><type>VkBool32</type> <name>persistent</name><comment>For smart displays, use buffered mode. If the display properties member "persistentMode" is VK_FALSE, this member must always be VK_FALSE.</comment></member>
+ </type>
+ <type category="struct" name="VkSurfaceCapabilitiesKHR" returnedonly="true">
+ <member><type>uint32_t</type> <name>minImageCount</name><comment>Supported minimum number of images for the surface</comment></member>
+ <member><type>uint32_t</type> <name>maxImageCount</name><comment>Supported maximum number of images for the surface, 0 for unlimited</comment></member>
+ <member><type>VkExtent2D</type> <name>currentExtent</name><comment>Current image width and height for the surface, (0, 0) if undefined</comment></member>
+ <member><type>VkExtent2D</type> <name>minImageExtent</name><comment>Supported minimum image width and height for the surface</comment></member>
+ <member><type>VkExtent2D</type> <name>maxImageExtent</name><comment>Supported maximum image width and height for the surface</comment></member>
+ <member><type>uint32_t</type> <name>maxImageArrayLayers</name><comment>Supported maximum number of image layers for the surface</comment></member>
+ <member optional="true"><type>VkSurfaceTransformFlagsKHR</type> <name>supportedTransforms</name><comment>1 or more bits representing the transforms supported</comment></member>
+ <member><type>VkSurfaceTransformFlagBitsKHR</type> <name>currentTransform</name><comment>The surface's current transform relative to the device's natural orientation</comment></member>
+ <member optional="true"><type>VkCompositeAlphaFlagsKHR</type> <name>supportedCompositeAlpha</name><comment>1 or more bits representing the alpha compositing modes supported</comment></member>
+ <member optional="true"><type>VkImageUsageFlags</type> <name>supportedUsageFlags</name><comment>Supported image usage flags for the surface</comment></member>
+ </type>
+ <type category="struct" name="VkAndroidSurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkAndroidSurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member noautovalidity="true">struct <type>ANativeWindow</type>* <name>window</name></member>
+ </type>
+ <type category="struct" name="VkMirSurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkMirSurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member noautovalidity="true"><type>MirConnection</type>* <name>connection</name></member>
+ <member noautovalidity="true"><type>MirSurface</type>* <name>mirSurface</name></member>
+ </type>
+ <type category="struct" name="VkViSurfaceCreateInfoNN">
+ <member values="VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkViSurfaceCreateFlagsNN</type> <name>flags</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>window</name></member>
+ </type>
+ <type category="struct" name="VkWaylandSurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkWaylandSurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member noautovalidity="true">struct <type>wl_display</type>* <name>display</name></member>
+ <member noautovalidity="true">struct <type>wl_surface</type>* <name>surface</name></member>
+ </type>
+ <type category="struct" name="VkWin32SurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkWin32SurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member><type>HINSTANCE</type> <name>hinstance</name></member>
+ <member><type>HWND</type> <name>hwnd</name></member>
+ </type>
+ <type category="struct" name="VkXlibSurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkXlibSurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member noautovalidity="true"><type>Display</type>* <name>dpy</name></member>
+ <member><type>Window</type> <name>window</name></member>
+ </type>
+ <type category="struct" name="VkXcbSurfaceCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkXcbSurfaceCreateFlagsKHR</type> <name>flags</name></member>
+ <member noautovalidity="true"><type>xcb_connection_t</type>* <name>connection</name></member>
+ <member><type>xcb_window_t</type> <name>window</name></member>
+ </type>
+ <type category="struct" name="VkSurfaceFormatKHR" returnedonly="true">
+ <member><type>VkFormat</type> <name>format</name><comment>Supported pair of rendering format</comment></member>
+ <member><type>VkColorSpaceKHR</type> <name>colorSpace</name><comment>and color space for the surface</comment></member>
+ </type>
+ <type category="struct" name="VkSwapchainCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkSwapchainCreateFlagsKHR</type> <name>flags</name></member>
+ <member><type>VkSurfaceKHR</type> <name>surface</name><comment>The swapchain's target surface</comment></member>
+ <member><type>uint32_t</type> <name>minImageCount</name><comment>Minimum number of presentation images the application needs</comment></member>
+ <member><type>VkFormat</type> <name>imageFormat</name><comment>Format of the presentation images</comment></member>
+ <member><type>VkColorSpaceKHR</type> <name>imageColorSpace</name><comment>Colorspace of the presentation images</comment></member>
+ <member><type>VkExtent2D</type> <name>imageExtent</name><comment>Dimensions of the presentation images</comment></member>
+ <member><type>uint32_t</type> <name>imageArrayLayers</name><comment>Determines the number of views for multiview/stereo presentation</comment></member>
+ <member><type>VkImageUsageFlags</type> <name>imageUsage</name><comment>Bits indicating how the presentation images will be used</comment></member>
+ <member><type>VkSharingMode</type> <name>imageSharingMode</name><comment>Sharing mode used for the presentation images</comment></member>
+ <member optional="true"><type>uint32_t</type> <name>queueFamilyIndexCount</name><comment>Number of queue families having access to the images in case of concurrent sharing mode</comment></member>
+ <member noautovalidity="true" len="queueFamilyIndexCount">const <type>uint32_t</type>* <name>pQueueFamilyIndices</name><comment>Array of queue family indices having access to the images in case of concurrent sharing mode</comment></member>
+ <member><type>VkSurfaceTransformFlagBitsKHR</type> <name>preTransform</name><comment>The transform, relative to the device's natural orientation, applied to the image content prior to presentation</comment></member>
+ <member><type>VkCompositeAlphaFlagBitsKHR</type> <name>compositeAlpha</name><comment>The alpha blending mode used when compositing this surface with other surfaces in the window system</comment></member>
+ <member><type>VkPresentModeKHR</type> <name>presentMode</name><comment>Which presentation mode to use for presents on this swap chain</comment></member>
+ <member><type>VkBool32</type> <name>clipped</name><comment>Specifies whether presentable images may be affected by window clip regions</comment></member>
+ <member optional="true"><type>VkSwapchainKHR</type> <name>oldSwapchain</name><comment>Existing swap chain to replace, if any</comment></member>
+ </type>
+ <type category="struct" name="VkPresentInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_PRESENT_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>waitSemaphoreCount</name><comment>Number of semaphores to wait for before presenting</comment></member>
+ <member len="waitSemaphoreCount">const <type>VkSemaphore</type>* <name>pWaitSemaphores</name><comment>Semaphores to wait for before presenting</comment></member>
+ <member><type>uint32_t</type> <name>swapchainCount</name><comment>Number of swapchains to present in this call</comment></member>
+ <member len="swapchainCount">const <type>VkSwapchainKHR</type>* <name>pSwapchains</name><comment>Swapchains to present an image from</comment></member>
+ <member len="swapchainCount">const <type>uint32_t</type>* <name>pImageIndices</name><comment>Indices of which presentable images to present</comment></member>
+ <member optional="true" len="swapchainCount"><type>VkResult</type>* <name>pResults</name><comment>Optional (i.e. if non-NULL) VkResult for each swapchain</comment></member>
+ </type>
+ <type category="struct" name="VkDebugReportCallbackCreateInfoEXT" structextends="VkInstanceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDebugReportFlagsEXT</type> <name>flags</name><comment>Indicates which events call this callback</comment></member>
+ <member><type>PFN_vkDebugReportCallbackEXT</type> <name>pfnCallback</name><comment>Function pointer of a callback function</comment></member>
+ <member optional="true"><type>void</type>* <name>pUserData</name><comment>User data provided to callback function</comment></member>
+ </type>
+ <type category="struct" name="VkValidationFlagsEXT" structextends="VkInstanceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT"><type>VkStructureType</type> <name>sType</name><comment>Must be VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT</comment></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>disabledValidationCheckCount</name><comment>Number of validation checks to disable</comment></member>
+ <member len="disabledValidationCheckCount"><type>VkValidationCheckEXT</type>* <name>pDisabledValidationChecks</name><comment>Validation checks to disable</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineRasterizationStateRasterizationOrderAMD" structextends="VkPipelineRasterizationStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkRasterizationOrderAMD</type> <name>rasterizationOrder</name><comment>Rasterization order to use for the pipeline</comment></member>
+ </type>
+ <type category="struct" name="VkDebugMarkerObjectNameInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDebugReportObjectTypeEXT</type> <name>objectType</name><comment>The type of the object</comment></member>
+ <member><type>uint64_t</type> <name>object</name><comment>The handle of the object, cast to uint64_t</comment></member>
+ <member len="null-terminated">const <type>char</type>* <name>pObjectName</name><comment>Name to apply to the object</comment></member>
+ </type>
+ <type category="struct" name="VkDebugMarkerObjectTagInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDebugReportObjectTypeEXT</type> <name>objectType</name><comment>The type of the object</comment></member>
+ <member><type>uint64_t</type> <name>object</name><comment>The handle of the object, cast to uint64_t</comment></member>
+ <member><type>uint64_t</type> <name>tagName</name><comment>The name of the tag to set on the object</comment></member>
+ <member><type>size_t</type> <name>tagSize</name><comment>The length in bytes of the tag data</comment></member>
+ <member len="tagSize">const <type>void</type>* <name>pTag</name><comment>Tag data to attach to the object</comment></member>
+ </type>
+ <type category="struct" name="VkDebugMarkerMarkerInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member len="null-terminated">const <type>char</type>* <name>pMarkerName</name><comment>Name of the debug marker</comment></member>
+ <member optional="true"><type>float</type> <name>color</name>[4]<comment>Optional color for debug marker</comment></member>
+ </type>
+ <type category="struct" name="VkDedicatedAllocationImageCreateInfoNV" structextends="VkImageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>dedicatedAllocation</name><comment>Whether this image uses a dedicated allocation</comment></member>
+ </type>
+ <type category="struct" name="VkDedicatedAllocationBufferCreateInfoNV" structextends="VkBufferCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>dedicatedAllocation</name><comment>Whether this buffer uses a dedicated allocation</comment></member>
+ </type>
+ <type category="struct" name="VkDedicatedAllocationMemoryAllocateInfoNV" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkImage</type> <name>image</name><comment>Image that this allocation will be bound to</comment></member>
+ <member optional="true"><type>VkBuffer</type> <name>buffer</name><comment>Buffer that this allocation will be bound to</comment></member>
+ </type>
+ <type category="struct" name="VkExternalImageFormatPropertiesNV" returnedonly="true">
+ <member><type>VkImageFormatProperties</type> <name>imageFormatProperties</name></member>
+ <member optional="true"><type>VkExternalMemoryFeatureFlagsNV</type> <name>externalMemoryFeatures</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>exportFromImportedHandleTypes</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>compatibleHandleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExternalMemoryImageCreateInfoNV" structextends="VkImageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExportMemoryAllocateInfoNV" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkImportMemoryWin32HandleInfoNV" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>handleType</name></member>
+ <member optional="true"><type>HANDLE</type> <name>handle</name></member>
+ </type>
+ <type category="struct" name="VkExportMemoryWin32HandleInfoNV" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true">const <type>SECURITY_ATTRIBUTES</type>* <name>pAttributes</name></member>
+ <member optional="true"><type>DWORD</type> <name>dwAccess</name></member>
+ </type>
+ <type category="struct" name="VkWin32KeyedMutexAcquireReleaseInfoNV" structextends="VkSubmitInfo">
+ <member values="VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>acquireCount</name></member>
+ <member len="acquireCount">const <type>VkDeviceMemory</type>* <name>pAcquireSyncs</name></member>
+ <member len="acquireCount">const <type>uint64_t</type>* <name>pAcquireKeys</name></member>
+ <member len="acquireCount">const <type>uint32_t</type>* <name>pAcquireTimeoutMilliseconds</name></member>
+ <member optional="true"><type>uint32_t</type> <name>releaseCount</name></member>
+ <member len="releaseCount">const <type>VkDeviceMemory</type>* <name>pReleaseSyncs</name></member>
+ <member len="releaseCount">const <type>uint64_t</type>* <name>pReleaseKeys</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGeneratedCommandsFeaturesNVX">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>computeBindingPointSupport</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGeneratedCommandsLimitsNVX">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxIndirectCommandsLayoutTokenCount</name></member>
+ <member><type>uint32_t</type> <name>maxObjectEntryCounts</name></member>
+ <member><type>uint32_t</type> <name>minSequenceCountBufferOffsetAlignment</name></member>
+ <member><type>uint32_t</type> <name>minSequenceIndexBufferOffsetAlignment</name></member>
+ <member><type>uint32_t</type> <name>minCommandsTokenBufferOffsetAlignment</name></member>
+ </type>
+ <type category="struct" name="VkIndirectCommandsTokenNVX">
+ <member><type>VkIndirectCommandsTokenTypeNVX</type> <name>tokenType</name></member>
+ <member><type>VkBuffer</type> <name>buffer</name><comment>buffer containing tableEntries and additional data for indirectCommands</comment></member>
+ <member><type>VkDeviceSize</type> <name>offset</name><comment>offset from the base address of the buffer</comment></member>
+ </type>
+ <type category="struct" name="VkIndirectCommandsLayoutTokenNVX">
+ <member><type>VkIndirectCommandsTokenTypeNVX</type> <name>tokenType</name></member>
+ <member><type>uint32_t</type> <name>bindingUnit</name><comment>Binding unit for vertex attribute / descriptor set, offset for pushconstants</comment></member>
+ <member><type>uint32_t</type> <name>dynamicCount</name><comment>Number of variable dynamic values for descriptor set / push constants</comment></member>
+ <member><type>uint32_t</type> <name>divisor</name><comment>Rate the which the array is advanced per element (must be power of 2, minimum 1)</comment></member>
+ </type>
+ <type category="struct" name="VkIndirectCommandsLayoutCreateInfoNVX">
+ <member values="VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkPipelineBindPoint</type> <name>pipelineBindPoint</name></member>
+ <member><type>VkIndirectCommandsLayoutUsageFlagsNVX</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>tokenCount</name></member>
+ <member len="tokenCount">const <type>VkIndirectCommandsLayoutTokenNVX</type>* <name>pTokens</name></member>
+ </type>
+ <type category="struct" name="VkCmdProcessCommandsInfoNVX">
+ <member values="VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkObjectTableNVX</type> <name>objectTable</name></member>
+ <member><type>VkIndirectCommandsLayoutNVX</type> <name>indirectCommandsLayout</name></member>
+ <member><type>uint32_t</type> <name>indirectCommandsTokenCount</name></member>
+ <member len="indirectCommandsTokenCount">const <type>VkIndirectCommandsTokenNVX</type>* <name>pIndirectCommandsTokens</name></member>
+ <member><type>uint32_t</type> <name>maxSequencesCount</name></member>
+ <member optional="true" externsync="true"><type>VkCommandBuffer</type> <name>targetCommandBuffer</name></member>
+ <member optional="true"><type>VkBuffer</type> <name>sequencesCountBuffer</name></member>
+ <member optional="true"><type>VkDeviceSize</type> <name>sequencesCountOffset</name></member>
+ <member optional="true"><type>VkBuffer</type> <name>sequencesIndexBuffer</name></member>
+ <member optional="true"><type>VkDeviceSize</type> <name>sequencesIndexOffset</name></member>
+ </type>
+ <type category="struct" name="VkCmdReserveSpaceForCommandsInfoNVX">
+ <member values="VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkObjectTableNVX</type> <name>objectTable</name></member>
+ <member><type>VkIndirectCommandsLayoutNVX</type> <name>indirectCommandsLayout</name></member>
+ <member><type>uint32_t</type> <name>maxSequencesCount</name></member>
+ </type>
+ <type category="struct" name="VkObjectTableCreateInfoNVX">
+ <member values="VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>objectCount</name></member>
+ <member len="objectCount">const <type>VkObjectEntryTypeNVX</type>* <name>pObjectEntryTypes</name></member>
+ <member len="objectCount">const <type>uint32_t</type>* <name>pObjectEntryCounts</name></member>
+ <member len="objectCount">const <type>VkObjectEntryUsageFlagsNVX</type>* <name>pObjectEntryUsageFlags</name></member>
+
+ <member><type>uint32_t</type> <name>maxUniformBuffersPerDescriptor</name></member>
+ <member><type>uint32_t</type> <name>maxStorageBuffersPerDescriptor</name></member>
+ <member><type>uint32_t</type> <name>maxStorageImagesPerDescriptor</name></member>
+ <member><type>uint32_t</type> <name>maxSampledImagesPerDescriptor</name></member>
+ <member><type>uint32_t</type> <name>maxPipelineLayouts</name></member>
+ </type>
+ <type category="struct" name="VkObjectTableEntryNVX">
+ <member><type>VkObjectEntryTypeNVX</type> <name>type</name></member>
+ <member><type>VkObjectEntryUsageFlagsNVX</type> <name>flags</name></member>
+ </type>
+ <type category="struct" name="VkObjectTablePipelineEntryNVX">
+ <member><type>VkObjectEntryTypeNVX</type> <name>type</name></member>
+ <member><type>VkObjectEntryUsageFlagsNVX</type> <name>flags</name></member>
+ <member><type>VkPipeline</type> <name>pipeline</name></member>
+ </type>
+ <type category="struct" name="VkObjectTableDescriptorSetEntryNVX">
+ <member><type>VkObjectEntryTypeNVX</type> <name>type</name></member>
+ <member><type>VkObjectEntryUsageFlagsNVX</type> <name>flags</name></member>
+ <member><type>VkPipelineLayout</type> <name>pipelineLayout</name></member>
+ <member><type>VkDescriptorSet</type> <name>descriptorSet</name></member>
+ </type>
+ <type category="struct" name="VkObjectTableVertexBufferEntryNVX">
+ <member><type>VkObjectEntryTypeNVX</type> <name>type</name></member>
+ <member><type>VkObjectEntryUsageFlagsNVX</type> <name>flags</name></member>
+ <member><type>VkBuffer</type> <name>buffer</name></member>
+ </type>
+ <type category="struct" name="VkObjectTableIndexBufferEntryNVX">
+ <member><type>VkObjectEntryTypeNVX</type> <name>type</name></member>
+ <member><type>VkObjectEntryUsageFlagsNVX</type> <name>flags</name></member>
+ <member><type>VkBuffer</type> <name>buffer</name></member>
+ <member><type>VkIndexType</type> <name>indexType</name></member>
+ </type>
+ <type category="struct" name="VkObjectTablePushConstantEntryNVX">
+ <member><type>VkObjectEntryTypeNVX</type> <name>type</name></member>
+ <member><type>VkObjectEntryUsageFlagsNVX</type> <name>flags</name></member>
+ <member><type>VkPipelineLayout</type> <name>pipelineLayout</name></member>
+ <member><type>VkShaderStageFlags</type> <name>stageFlags</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceFeatures2" structextends="VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkPhysicalDeviceFeatures</type> <name>features</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceFeatures2KHR" alias="VkPhysicalDeviceFeatures2"/>
+ <type category="struct" name="VkPhysicalDeviceProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkPhysicalDeviceProperties</type> <name>properties</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceProperties2KHR" alias="VkPhysicalDeviceProperties2"/>
+ <type category="struct" name="VkFormatProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkFormatProperties</type> <name>formatProperties</name></member>
+ </type>
+ <type category="struct" name="VkFormatProperties2KHR" alias="VkFormatProperties2"/>
+ <type category="struct" name="VkImageFormatProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkImageFormatProperties</type> <name>imageFormatProperties</name></member>
+ </type>
+ <type category="struct" name="VkImageFormatProperties2KHR" alias="VkImageFormatProperties2"/>
+ <type category="struct" name="VkPhysicalDeviceImageFormatInfo2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>VkImageType</type> <name>type</name></member>
+ <member><type>VkImageTiling</type> <name>tiling</name></member>
+ <member><type>VkImageUsageFlags</type> <name>usage</name></member>
+ <member optional="true"><type>VkImageCreateFlags</type> <name>flags</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceImageFormatInfo2KHR" alias="VkPhysicalDeviceImageFormatInfo2"/>
+ <type category="struct" name="VkQueueFamilyProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkQueueFamilyProperties</type> <name>queueFamilyProperties</name></member>
+ </type>
+ <type category="struct" name="VkQueueFamilyProperties2KHR" alias="VkQueueFamilyProperties2"/>
+ <type category="struct" name="VkPhysicalDeviceMemoryProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkPhysicalDeviceMemoryProperties</type> <name>memoryProperties</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMemoryProperties2KHR" alias="VkPhysicalDeviceMemoryProperties2"/>
+ <type category="struct" name="VkSparseImageFormatProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkSparseImageFormatProperties</type> <name>properties</name></member>
+ </type>
+ <type category="struct" name="VkSparseImageFormatProperties2KHR" alias="VkSparseImageFormatProperties2"/>
+ <type category="struct" name="VkPhysicalDeviceSparseImageFormatInfo2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>VkImageType</type> <name>type</name></member>
+ <member><type>VkSampleCountFlagBits</type> <name>samples</name></member>
+ <member><type>VkImageUsageFlags</type> <name>usage</name></member>
+ <member><type>VkImageTiling</type> <name>tiling</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceSparseImageFormatInfo2KHR" alias="VkPhysicalDeviceSparseImageFormatInfo2"/>
+ <type category="struct" name="VkPhysicalDevicePushDescriptorPropertiesKHR" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxPushDescriptors</name></member>
+ </type>
+ <type category="struct" name="VkPresentRegionsKHR" structextends="VkPresentInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>swapchainCount</name><comment>Copy of VkPresentInfoKHR::swapchainCount</comment></member>
+ <member len="swapchainCount" optional="true">const <type>VkPresentRegionKHR</type>* <name>pRegions</name><comment>The regions that have changed</comment></member>
+ </type>
+ <type category="struct" name="VkPresentRegionKHR">
+ <member optional="true"><type>uint32_t</type> <name>rectangleCount</name><comment>Number of rectangles in pRectangles</comment></member>
+ <member optional="true" len="rectangleCount">const <type>VkRectLayerKHR</type>* <name>pRectangles</name><comment>Array of rectangles that have changed in a swapchain's image(s)</comment></member>
+ </type>
+ <type category="struct" name="VkRectLayerKHR">
+ <member><type>VkOffset2D</type> <name>offset</name><comment>upper-left corner of a rectangle that has not changed, in pixels of a presentation images</comment></member>
+ <member><type>VkExtent2D</type> <name>extent</name><comment>Dimensions of a rectangle that has not changed, in pixels of a presentation images</comment></member>
+ <member><type>uint32_t</type> <name>layer</name><comment>Layer of a swapchain's image(s), for stereoscopic-3D images</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceVariablePointerFeatures" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>variablePointersStorageBuffer</name></member>
+ <member><type>VkBool32</type> <name>variablePointers</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceVariablePointerFeaturesKHR" alias="VkPhysicalDeviceVariablePointerFeatures"/>
+ <type category="struct" name="VkExternalMemoryProperties" returnedonly="true">
+ <member><type>VkExternalMemoryFeatureFlags</type> <name>externalMemoryFeatures</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlags</type> <name>exportFromImportedHandleTypes</name></member>
+ <member><type>VkExternalMemoryHandleTypeFlags</type> <name>compatibleHandleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExternalMemoryPropertiesKHR" alias="VkExternalMemoryProperties"/>
+ <type category="struct" name="VkPhysicalDeviceExternalImageFormatInfo" structextends="VkPhysicalDeviceImageFormatInfo2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalImageFormatInfoKHR" alias="VkPhysicalDeviceExternalImageFormatInfo"/>
+ <type category="struct" name="VkExternalImageFormatProperties" returnedonly="true" structextends="VkImageFormatProperties2">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalMemoryProperties</type> <name>externalMemoryProperties</name></member>
+ </type>
+ <type category="struct" name="VkExternalImageFormatPropertiesKHR" alias="VkExternalImageFormatProperties"/>
+ <type category="struct" name="VkPhysicalDeviceExternalBufferInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkBufferCreateFlags</type> <name>flags</name></member>
+ <member><type>VkBufferUsageFlags</type> <name>usage</name></member>
+ <member><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalBufferInfoKHR" alias="VkPhysicalDeviceExternalBufferInfo"/>
+ <type category="struct" name="VkExternalBufferProperties" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalMemoryProperties</type> <name>externalMemoryProperties</name></member>
+ </type>
+ <type category="struct" name="VkExternalBufferPropertiesKHR" alias="VkExternalBufferProperties"/>
+ <type category="struct" name="VkPhysicalDeviceIDProperties" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint8_t</type> <name>deviceUUID</name>[<enum>VK_UUID_SIZE</enum>]</member>
+ <member><type>uint8_t</type> <name>driverUUID</name>[<enum>VK_UUID_SIZE</enum>]</member>
+ <member><type>uint8_t</type> <name>deviceLUID</name>[<enum>VK_LUID_SIZE</enum>]</member>
+ <member><type>uint32_t</type> <name>deviceNodeMask</name></member>
+ <member><type>VkBool32</type> <name>deviceLUIDValid</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceIDPropertiesKHR" alias="VkPhysicalDeviceIDProperties"/>
+ <type category="struct" name="VkExternalMemoryImageCreateInfo" structextends="VkImageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalMemoryHandleTypeFlags</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExternalMemoryImageCreateInfoKHR" alias="VkExternalMemoryImageCreateInfo"/>
+ <type category="struct" name="VkExternalMemoryBufferCreateInfo" structextends="VkBufferCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlags</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExternalMemoryBufferCreateInfoKHR" alias="VkExternalMemoryBufferCreateInfo"/>
+ <type category="struct" name="VkExportMemoryAllocateInfo" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlags</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExportMemoryAllocateInfoKHR" alias="VkExportMemoryAllocateInfo"/>
+ <type category="struct" name="VkImportMemoryWin32HandleInfoKHR" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member optional="true"><type>HANDLE</type> <name>handle</name></member>
+ <member optional="true"><type>LPCWSTR</type> <name>name</name></member>
+ </type>
+ <type category="struct" name="VkExportMemoryWin32HandleInfoKHR" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true">const <type>SECURITY_ATTRIBUTES</type>* <name>pAttributes</name></member>
+ <member><type>DWORD</type> <name>dwAccess</name></member>
+ <member><type>LPCWSTR</type> <name>name</name></member>
+ </type>
+ <type category="struct" name="VkMemoryWin32HandlePropertiesKHR" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_WIN32_HANDLE_PROPERTIES_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>memoryTypeBits</name></member>
+ </type>
+ <type category="struct" name="VkMemoryGetWin32HandleInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_GET_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceMemory</type> <name>memory</name></member>
+ <member><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkImportMemoryFdInfoKHR" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member><type>int</type> <name>fd</name></member>
+ </type>
+ <type category="struct" name="VkMemoryFdPropertiesKHR" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_FD_PROPERTIES_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>memoryTypeBits</name></member>
+ </type>
+ <type category="struct" name="VkMemoryGetFdInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceMemory</type> <name>memory</name></member>
+ <member><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkWin32KeyedMutexAcquireReleaseInfoKHR" structextends="VkSubmitInfo">
+ <member values="VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>acquireCount</name></member>
+ <member len="acquireCount">const <type>VkDeviceMemory</type>* <name>pAcquireSyncs</name></member>
+ <member len="acquireCount">const <type>uint64_t</type>* <name>pAcquireKeys</name></member>
+ <member len="acquireCount">const <type>uint32_t</type>* <name>pAcquireTimeouts</name></member>
+ <member optional="true"><type>uint32_t</type> <name>releaseCount</name></member>
+ <member len="releaseCount">const <type>VkDeviceMemory</type>* <name>pReleaseSyncs</name></member>
+ <member len="releaseCount">const <type>uint64_t</type>* <name>pReleaseKeys</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalSemaphoreInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalSemaphoreHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalSemaphoreInfoKHR" alias="VkPhysicalDeviceExternalSemaphoreInfo"/>
+ <type category="struct" name="VkExternalSemaphoreProperties" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalSemaphoreHandleTypeFlags</type> <name>exportFromImportedHandleTypes</name></member>
+ <member><type>VkExternalSemaphoreHandleTypeFlags</type> <name>compatibleHandleTypes</name></member>
+ <member optional="true"><type>VkExternalSemaphoreFeatureFlags</type> <name>externalSemaphoreFeatures</name></member>
+ </type>
+ <type category="struct" name="VkExternalSemaphorePropertiesKHR" alias="VkExternalSemaphoreProperties"/>
+ <type category="struct" name="VkExportSemaphoreCreateInfo" structextends="VkSemaphoreCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalSemaphoreHandleTypeFlags</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExportSemaphoreCreateInfoKHR" alias="VkExportSemaphoreCreateInfo"/>
+ <type category="struct" name="VkImportSemaphoreWin32HandleInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkSemaphore</type> <name>semaphore</name></member>
+ <member optional="true"><type>VkSemaphoreImportFlags</type> <name>flags</name></member>
+ <member optional="true"><type>VkExternalSemaphoreHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member optional="true"><type>HANDLE</type> <name>handle</name></member>
+ <member optional="true"><type>LPCWSTR</type> <name>name</name></member>
+ </type>
+ <type category="struct" name="VkExportSemaphoreWin32HandleInfoKHR" structextends="VkSemaphoreCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true">const <type>SECURITY_ATTRIBUTES</type>* <name>pAttributes</name></member>
+ <member><type>DWORD</type> <name>dwAccess</name></member>
+ <member><type>LPCWSTR</type> <name>name</name></member>
+ </type>
+ <type category="struct" name="VkD3D12FenceSubmitInfoKHR" structextends="VkSubmitInfo">
+ <member values="VK_STRUCTURE_TYPE_D3D12_FENCE_SUBMIT_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>waitSemaphoreValuesCount</name></member>
+ <member optional="true" len="waitSemaphoreValuesCount">const <type>uint64_t</type>* <name>pWaitSemaphoreValues</name></member>
+ <member optional="true"><type>uint32_t</type> <name>signalSemaphoreValuesCount</name></member>
+ <member optional="true" len="signalSemaphoreValuesCount">const <type>uint64_t</type>* <name>pSignalSemaphoreValues</name></member>
+ </type>
+ <type category="struct" name="VkSemaphoreGetWin32HandleInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_SEMAPHORE_GET_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkSemaphore</type> <name>semaphore</name></member>
+ <member><type>VkExternalSemaphoreHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkImportSemaphoreFdInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkSemaphore</type> <name>semaphore</name></member>
+ <member optional="true"><type>VkSemaphoreImportFlags</type> <name>flags</name></member>
+ <member><type>VkExternalSemaphoreHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member><type>int</type> <name>fd</name></member>
+ </type>
+ <type category="struct" name="VkSemaphoreGetFdInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkSemaphore</type> <name>semaphore</name></member>
+ <member><type>VkExternalSemaphoreHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalFenceInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalFenceHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalFenceInfoKHR" alias="VkPhysicalDeviceExternalFenceInfo"/>
+ <type category="struct" name="VkExternalFenceProperties" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalFenceHandleTypeFlags</type> <name>exportFromImportedHandleTypes</name></member>
+ <member><type>VkExternalFenceHandleTypeFlags</type> <name>compatibleHandleTypes</name></member>
+ <member optional="true"><type>VkExternalFenceFeatureFlags</type> <name>externalFenceFeatures</name></member>
+ </type>
+ <type category="struct" name="VkExternalFencePropertiesKHR" alias="VkExternalFenceProperties"/>
+ <type category="struct" name="VkExportFenceCreateInfo" structextends="VkFenceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkExternalFenceHandleTypeFlags</type> <name>handleTypes</name></member>
+ </type>
+ <type category="struct" name="VkExportFenceCreateInfoKHR" alias="VkExportFenceCreateInfo"/>
+ <type category="struct" name="VkImportFenceWin32HandleInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_FENCE_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkFence</type> <name>fence</name></member>
+ <member optional="true"><type>VkFenceImportFlags</type> <name>flags</name></member>
+ <member optional="true"><type>VkExternalFenceHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member optional="true"><type>HANDLE</type> <name>handle</name></member>
+ <member optional="true"><type>LPCWSTR</type> <name>name</name></member>
+ </type>
+ <type category="struct" name="VkExportFenceWin32HandleInfoKHR" structextends="VkFenceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXPORT_FENCE_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true">const <type>SECURITY_ATTRIBUTES</type>* <name>pAttributes</name></member>
+ <member><type>DWORD</type> <name>dwAccess</name></member>
+ <member><type>LPCWSTR</type> <name>name</name></member>
+ </type>
+ <type category="struct" name="VkFenceGetWin32HandleInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_FENCE_GET_WIN32_HANDLE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkFence</type> <name>fence</name></member>
+ <member><type>VkExternalFenceHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkImportFenceFdInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkFence</type> <name>fence</name></member>
+ <member optional="true"><type>VkFenceImportFlags</type> <name>flags</name></member>
+ <member><type>VkExternalFenceHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member><type>int</type> <name>fd</name></member>
+ </type>
+ <type category="struct" name="VkFenceGetFdInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkFence</type> <name>fence</name></member>
+ <member><type>VkExternalFenceHandleTypeFlagBits</type> <name>handleType</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMultiviewFeatures" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>multiview</name><comment>Multiple views in a renderpass</comment></member>
+ <member><type>VkBool32</type> <name>multiviewGeometryShader</name><comment>Multiple views in a renderpass w/ geometry shader</comment></member>
+ <member><type>VkBool32</type> <name>multiviewTessellationShader</name><comment>Multiple views in a renderpass w/ tessellation shader</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMultiviewFeaturesKHR" alias="VkPhysicalDeviceMultiviewFeatures"/>
+ <type category="struct" name="VkPhysicalDeviceMultiviewProperties" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxMultiviewViewCount</name><comment>max number of views in a subpass</comment></member>
+ <member><type>uint32_t</type> <name>maxMultiviewInstanceIndex</name><comment>max instance index for a draw in a multiview subpass</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMultiviewPropertiesKHR" alias="VkPhysicalDeviceMultiviewProperties"/>
+ <type category="struct" name="VkRenderPassMultiviewCreateInfo" structextends="VkRenderPassCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>subpassCount</name></member>
+ <member len="subpassCount">const <type>uint32_t</type>* <name>pViewMasks</name></member>
+ <member optional="true"><type>uint32_t</type> <name>dependencyCount</name></member>
+ <member len="dependencyCount">const <type>int32_t</type>* <name>pViewOffsets</name></member>
+ <member optional="true"><type>uint32_t</type> <name>correlationMaskCount</name></member>
+ <member len="correlationMaskCount">const <type>uint32_t</type>* <name>pCorrelationMasks</name></member>
+ </type>
+ <type category="struct" name="VkRenderPassMultiviewCreateInfoKHR" alias="VkRenderPassMultiviewCreateInfo"/>
+ <type category="struct" name="VkSurfaceCapabilities2EXT" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>minImageCount</name><comment>Supported minimum number of images for the surface</comment></member>
+ <member><type>uint32_t</type> <name>maxImageCount</name><comment>Supported maximum number of images for the surface, 0 for unlimited</comment></member>
+ <member><type>VkExtent2D</type> <name>currentExtent</name><comment>Current image width and height for the surface, (0, 0) if undefined</comment></member>
+ <member><type>VkExtent2D</type> <name>minImageExtent</name><comment>Supported minimum image width and height for the surface</comment></member>
+ <member><type>VkExtent2D</type> <name>maxImageExtent</name><comment>Supported maximum image width and height for the surface</comment></member>
+ <member><type>uint32_t</type> <name>maxImageArrayLayers</name><comment>Supported maximum number of image layers for the surface</comment></member>
+ <member optional="true"><type>VkSurfaceTransformFlagsKHR</type> <name>supportedTransforms</name><comment>1 or more bits representing the transforms supported</comment></member>
+ <member><type>VkSurfaceTransformFlagBitsKHR</type> <name>currentTransform</name><comment>The surface's current transform relative to the device's natural orientation</comment></member>
+ <member optional="true"><type>VkCompositeAlphaFlagsKHR</type> <name>supportedCompositeAlpha</name><comment>1 or more bits representing the alpha compositing modes supported</comment></member>
+ <member optional="true"><type>VkImageUsageFlags</type> <name>supportedUsageFlags</name><comment>Supported image usage flags for the surface</comment></member>
+ <member optional="true"><type>VkSurfaceCounterFlagsEXT</type> <name>supportedSurfaceCounters</name></member>
+ </type>
+ <type category="struct" name="VkDisplayPowerInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDisplayPowerStateEXT</type> <name>powerState</name></member>
+ </type>
+ <type category="struct" name="VkDeviceEventInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceEventTypeEXT</type> <name>deviceEvent</name></member>
+ </type>
+ <type category="struct" name="VkDisplayEventInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDisplayEventTypeEXT</type> <name>displayEvent</name></member>
+ </type>
+ <type category="struct" name="VkSwapchainCounterCreateInfoEXT" structextends="VkSwapchainCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkSurfaceCounterFlagsEXT</type> <name>surfaceCounters</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceGroupProperties" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>physicalDeviceCount</name></member>
+ <member><type>VkPhysicalDevice</type> <name>physicalDevices</name>[<enum>VK_MAX_DEVICE_GROUP_SIZE</enum>]</member>
+ <member><type>VkBool32</type> <name>subsetAllocation</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceGroupPropertiesKHR" alias="VkPhysicalDeviceGroupProperties"/>
+ <type category="struct" name="VkMemoryAllocateFlagsInfo" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkMemoryAllocateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>deviceMask</name></member>
+ </type>
+ <type category="struct" name="VkMemoryAllocateFlagsInfoKHR" alias="VkMemoryAllocateFlagsInfo"/>
+ <type category="struct" name="VkBindBufferMemoryInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBuffer</type> <name>buffer</name></member>
+ <member><type>VkDeviceMemory</type> <name>memory</name></member>
+ <member><type>VkDeviceSize</type> <name>memoryOffset</name></member>
+ </type>
+ <type category="struct" name="VkBindBufferMemoryInfoKHR" alias="VkBindBufferMemoryInfo"/>
+ <type category="struct" name="VkBindBufferMemoryDeviceGroupInfo" structextends="VkBindBufferMemoryInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>deviceIndexCount</name></member>
+ <member len="deviceIndexCount">const <type>uint32_t</type>* <name>pDeviceIndices</name></member>
+ </type>
+ <type category="struct" name="VkBindBufferMemoryDeviceGroupInfoKHR" alias="VkBindBufferMemoryDeviceGroupInfo"/>
+ <type category="struct" name="VkBindImageMemoryInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkImage</type> <name>image</name></member>
+ <member noautovalidity="true"><type>VkDeviceMemory</type> <name>memory</name></member>
+ <member><type>VkDeviceSize</type> <name>memoryOffset</name></member>
+ </type>
+ <type category="struct" name="VkBindImageMemoryInfoKHR" alias="VkBindImageMemoryInfo"/>
+ <type category="struct" name="VkBindImageMemoryDeviceGroupInfo" structextends="VkBindImageMemoryInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>deviceIndexCount</name></member>
+ <member len="deviceIndexCount">const <type>uint32_t</type>* <name>pDeviceIndices</name></member>
+ <member optional="true"><type>uint32_t</type> <name>splitInstanceBindRegionCount</name></member>
+ <member len="splitInstanceBindRegionCount">const <type>VkRect2D</type>* <name>pSplitInstanceBindRegions</name></member>
+ </type>
+ <type category="struct" name="VkBindImageMemoryDeviceGroupInfoKHR" alias="VkBindImageMemoryDeviceGroupInfo"/>
+ <type category="struct" name="VkDeviceGroupRenderPassBeginInfo" structextends="VkRenderPassBeginInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>deviceMask</name></member>
+ <member optional="true"><type>uint32_t</type> <name>deviceRenderAreaCount</name></member>
+ <member len="deviceRenderAreaCount">const <type>VkRect2D</type>* <name>pDeviceRenderAreas</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupRenderPassBeginInfoKHR" alias="VkDeviceGroupRenderPassBeginInfo"/>
+ <type category="struct" name="VkDeviceGroupCommandBufferBeginInfo" structextends="VkCommandBufferBeginInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>deviceMask</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupCommandBufferBeginInfoKHR" alias="VkDeviceGroupCommandBufferBeginInfo"/>
+ <type category="struct" name="VkDeviceGroupSubmitInfo" structextends="VkSubmitInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>waitSemaphoreCount</name></member>
+ <member len="waitSemaphoreCount">const <type>uint32_t</type>* <name>pWaitSemaphoreDeviceIndices</name></member>
+ <member optional="true"><type>uint32_t</type> <name>commandBufferCount</name></member>
+ <member len="commandBufferCount">const <type>uint32_t</type>* <name>pCommandBufferDeviceMasks</name></member>
+ <member optional="true"><type>uint32_t</type> <name>signalSemaphoreCount</name></member>
+ <member len="signalSemaphoreCount">const <type>uint32_t</type>* <name>pSignalSemaphoreDeviceIndices</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupSubmitInfoKHR" alias="VkDeviceGroupSubmitInfo"/>
+ <type category="struct" name="VkDeviceGroupBindSparseInfo" structextends="VkBindSparseInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>resourceDeviceIndex</name></member>
+ <member><type>uint32_t</type> <name>memoryDeviceIndex</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupBindSparseInfoKHR" alias="VkDeviceGroupBindSparseInfo"/>
+ <type category="struct" name="VkDeviceGroupPresentCapabilitiesKHR" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>presentMask</name>[<enum>VK_MAX_DEVICE_GROUP_SIZE</enum>]</member>
+ <member><type>VkDeviceGroupPresentModeFlagsKHR</type> <name>modes</name></member>
+ </type>
+ <type category="struct" name="VkImageSwapchainCreateInfoKHR" structextends="VkImageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkSwapchainKHR</type> <name>swapchain</name></member>
+ </type>
+ <type category="struct" name="VkBindImageMemorySwapchainInfoKHR" structextends="VkBindImageMemoryInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></member>
+ <member><type>uint32_t</type> <name>imageIndex</name></member>
+ </type>
+ <type category="struct" name="VkAcquireNextImageInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></member>
+ <member><type>uint64_t</type> <name>timeout</name></member>
+ <member optional="true" externsync="true"><type>VkSemaphore</type> <name>semaphore</name></member>
+ <member optional="true" externsync="true"><type>VkFence</type> <name>fence</name></member>
+ <member><type>uint32_t</type> <name>deviceMask</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupPresentInfoKHR" structextends="VkPresentInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>swapchainCount</name></member>
+ <member len="swapchainCount">const <type>uint32_t</type>* <name>pDeviceMasks</name></member>
+ <member><type>VkDeviceGroupPresentModeFlagBitsKHR</type> <name>mode</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupDeviceCreateInfo" structextends="VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>physicalDeviceCount</name></member>
+ <member len="physicalDeviceCount">const <type>VkPhysicalDevice</type>* <name>pPhysicalDevices</name></member>
+ </type>
+ <type category="struct" name="VkDeviceGroupDeviceCreateInfoKHR" alias="VkDeviceGroupDeviceCreateInfo"/>
+ <type category="struct" name="VkDeviceGroupSwapchainCreateInfoKHR" structextends="VkSwapchainCreateInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceGroupPresentModeFlagsKHR</type> <name>modes</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorUpdateTemplateEntry">
+ <member><type>uint32_t</type> <name>dstBinding</name><comment>Binding within the destination descriptor set to write</comment></member>
+ <member><type>uint32_t</type> <name>dstArrayElement</name><comment>Array element within the destination binding to write</comment></member>
+ <member><type>uint32_t</type> <name>descriptorCount</name><comment>Number of descriptors to write</comment></member>
+ <member><type>VkDescriptorType</type> <name>descriptorType</name><comment>Descriptor type to write</comment></member>
+ <member><type>size_t</type> <name>offset</name><comment>Offset into pData where the descriptors to update are stored</comment></member>
+ <member><type>size_t</type> <name>stride</name><comment>Stride between two descriptors in pData when writing more than one descriptor</comment></member>
+ </type>
+ <type category="struct" name="VkDescriptorUpdateTemplateEntryKHR" alias="VkDescriptorUpdateTemplateEntry"/>
+ <type category="struct" name="VkDescriptorUpdateTemplateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDescriptorUpdateTemplateCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>descriptorUpdateEntryCount</name><comment>Number of descriptor update entries to use for the update template</comment></member>
+ <member len="descriptorUpdateEntryCount">const <type>VkDescriptorUpdateTemplateEntry</type>* <name>pDescriptorUpdateEntries</name><comment>Descriptor update entries for the template</comment></member>
+ <member><type>VkDescriptorUpdateTemplateType</type> <name>templateType</name></member>
+ <member optional="true"><type>VkDescriptorSetLayout</type> <name>descriptorSetLayout</name></member>
+ <member noautovalidity="true"><type>VkPipelineBindPoint</type> <name>pipelineBindPoint</name></member>
+ <member noautovalidity="true"><type>VkPipelineLayout</type><name>pipelineLayout</name><comment>If used for push descriptors, this is the only allowed layout</comment></member>
+ <member noautovalidity="true"><type>uint32_t</type> <name>set</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorUpdateTemplateCreateInfoKHR" alias="VkDescriptorUpdateTemplateCreateInfo"/>
+ <type category="struct" name="VkXYColorEXT" comment="Chromaticity coordinate">
+ <member><type>float</type> <name>x</name></member>
+ <member><type>float</type> <name>y</name></member>
+ </type>
+ <type category="struct" name="VkHdrMetadataEXT">
+ <comment>Display primary in chromaticity coordinates</comment>
+ <member values="VK_STRUCTURE_TYPE_HDR_METADATA_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <comment> From SMPTE 2086</comment>
+ <member><type>VkXYColorEXT</type> <name>displayPrimaryRed</name><comment>Display primary's Red</comment></member>
+ <member><type>VkXYColorEXT</type> <name>displayPrimaryGreen</name><comment>Display primary's Green</comment></member>
+ <member><type>VkXYColorEXT</type> <name>displayPrimaryBlue</name><comment>Display primary's Blue</comment></member>
+ <member><type>VkXYColorEXT</type> <name>whitePoint</name><comment>Display primary's Blue</comment></member>
+ <member><type>float</type> <name>maxLuminance</name><comment>Display maximum luminance</comment></member>
+ <member><type>float</type> <name>minLuminance</name><comment>Display minimum luminance</comment></member>
+ <comment> From CTA 861.3</comment>
+ <member><type>float</type> <name>maxContentLightLevel</name><comment>Content maximum luminance</comment></member>
+ <member><type>float</type> <name>maxFrameAverageLightLevel</name></member>
+ </type>
+ <type category="struct" name="VkRefreshCycleDurationGOOGLE">
+ <member><type>uint64_t</type> <name>refreshDuration</name><comment>Number of nanoseconds from the start of one refresh cycle to the next</comment></member>
+ </type>
+ <type category="struct" name="VkPastPresentationTimingGOOGLE">
+ <member><type>uint32_t</type> <name>presentID</name><comment>Application-provided identifier, previously given to vkQueuePresentKHR</comment></member>
+ <member><type>uint64_t</type> <name>desiredPresentTime</name><comment>Earliest time an image should have been presented, previously given to vkQueuePresentKHR</comment></member>
+ <member><type>uint64_t</type> <name>actualPresentTime</name><comment>Time the image was actually displayed</comment></member>
+ <member><type>uint64_t</type> <name>earliestPresentTime</name><comment>Earliest time the image could have been displayed</comment></member>
+ <member><type>uint64_t</type> <name>presentMargin</name><comment>How early vkQueuePresentKHR was processed vs. how soon it needed to be and make earliestPresentTime</comment></member>
+ </type>
+ <type category="struct" name="VkPresentTimesInfoGOOGLE" structextends="VkPresentInfoKHR">
+ <member values="VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>swapchainCount</name><comment>Copy of VkPresentInfoKHR::swapchainCount</comment></member>
+ <member len="swapchainCount" optional="true">const <type>VkPresentTimeGOOGLE</type>* <name>pTimes</name><comment>The earliest times to present images</comment></member>
+ </type>
+ <type category="struct" name="VkPresentTimeGOOGLE">
+ <member><type>uint32_t</type> <name>presentID</name><comment>Application-provided identifier</comment></member>
+ <member><type>uint64_t</type> <name>desiredPresentTime</name><comment>Earliest time an image should be presented</comment></member>
+ </type>
+ <type category="struct" name="VkIOSSurfaceCreateInfoMVK">
+ <member values="VK_STRUCTURE_TYPE_IOS_SURFACE_CREATE_INFO_MVK"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkIOSSurfaceCreateFlagsMVK</type> <name>flags</name></member>
+ <member noautovalidity="true">const <type>void</type>* <name>pView</name></member>
+ </type>
+ <type category="struct" name="VkMacOSSurfaceCreateInfoMVK">
+ <member values="VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkMacOSSurfaceCreateFlagsMVK</type> <name>flags</name></member>
+ <member noautovalidity="true">const <type>void</type>* <name>pView</name></member>
+ </type>
+ <type category="struct" name="VkViewportWScalingNV">
+ <member><type>float</type> <name>xcoeff</name></member>
+ <member><type>float</type> <name>ycoeff</name></member>
+ </type>
+ <type category="struct" name="VkPipelineViewportWScalingStateCreateInfoNV" structextends="VkPipelineViewportStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>viewportWScalingEnable</name></member>
+ <member><type>uint32_t</type> <name>viewportCount</name></member>
+ <member noautovalidity="true" len="viewportCount">const <type>VkViewportWScalingNV</type>* <name>pViewportWScalings</name></member>
+ </type>
+ <type category="struct" name="VkViewportSwizzleNV">
+ <member><type>VkViewportCoordinateSwizzleNV</type> <name>x</name></member>
+ <member><type>VkViewportCoordinateSwizzleNV</type> <name>y</name></member>
+ <member><type>VkViewportCoordinateSwizzleNV</type> <name>z</name></member>
+ <member><type>VkViewportCoordinateSwizzleNV</type> <name>w</name></member>
+ </type>
+ <type category="struct" name="VkPipelineViewportSwizzleStateCreateInfoNV" structextends="VkPipelineViewportStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineViewportSwizzleStateCreateFlagsNV</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>viewportCount</name></member>
+ <member noautovalidity="true" optional="true" len="viewportCount">const <type>VkViewportSwizzleNV</type>* <name>pViewportSwizzles</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceDiscardRectanglePropertiesEXT" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxDiscardRectangles</name><comment>max number of active discard rectangles</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineDiscardRectangleStateCreateInfoEXT" structextends="VkGraphicsPipelineCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineDiscardRectangleStateCreateFlagsEXT</type> <name>flags</name></member>
+ <member><type>VkDiscardRectangleModeEXT</type> <name>discardRectangleMode</name></member>
+ <member optional="true"><type>uint32_t</type> <name>discardRectangleCount</name></member>
+ <member noautovalidity="true" optional="true" len="discardRectangleCount">const <type>VkRect2D</type>* <name>pDiscardRectangles</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>perViewPositionAllComponents</name></member>
+ </type>
+ <type category="struct" name="VkInputAttachmentAspectReference">
+ <member><type>uint32_t</type> <name>subpass</name></member>
+ <member><type>uint32_t</type> <name>inputAttachmentIndex</name></member>
+ <member><type>VkImageAspectFlags</type> <name>aspectMask</name></member>
+ </type>
+ <type category="struct" name="VkInputAttachmentAspectReferenceKHR" alias="VkInputAttachmentAspectReference"/>
+ <type category="struct" name="VkRenderPassInputAttachmentAspectCreateInfo" structextends="VkRenderPassCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>aspectReferenceCount</name></member>
+ <member len="aspectReferenceCount">const <type>VkInputAttachmentAspectReference</type>* <name>pAspectReferences</name></member>
+ </type>
+ <type category="struct" name="VkRenderPassInputAttachmentAspectCreateInfoKHR" alias="VkRenderPassInputAttachmentAspectCreateInfo"/>
+ <type category="struct" name="VkPhysicalDeviceSurfaceInfo2KHR">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkSurfaceKHR</type> <name>surface</name></member>
+ </type>
+ <type category="struct" name="VkSurfaceCapabilities2KHR" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkSurfaceCapabilitiesKHR</type> <name>surfaceCapabilities</name></member>
+ </type>
+ <type category="struct" name="VkSurfaceFormat2KHR" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkSurfaceFormatKHR</type> <name>surfaceFormat</name></member>
+ </type>
+ <type category="struct" name="VkSharedPresentSurfaceCapabilitiesKHR" returnedonly="true" structextends="VkSurfaceCapabilities2KHR">
+ <member values="VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkImageUsageFlags</type> <name>sharedPresentSupportedUsageFlags</name><comment>Supported image usage flags if swapchain created using a shared present mode</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDevice16BitStorageFeatures" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>storageBuffer16BitAccess</name><comment>16-bit integer/floating-point variables supported in BufferBlock</comment></member>
+ <member><type>VkBool32</type> <name>uniformAndStorageBuffer16BitAccess</name><comment>16-bit integer/floating-point variables supported in BufferBlock and Block</comment></member>
+ <member><type>VkBool32</type> <name>storagePushConstant16</name><comment>16-bit integer/floating-point variables supported in PushConstant</comment></member>
+ <member><type>VkBool32</type> <name>storageInputOutput16</name><comment>16-bit integer/floating-point variables supported in shader inputs and outputs</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDevice16BitStorageFeaturesKHR" alias="VkPhysicalDevice16BitStorageFeatures"/>
+ <type category="struct" name="VkPhysicalDeviceSubgroupProperties" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member noautovalidity="true"><type>uint32_t</type> <name>subgroupSize</name><comment>The size of a subgroup for this queue.</comment></member>
+ <member noautovalidity="true"><type>VkShaderStageFlags</type> <name>supportedStages</name><comment>Bitfield of what shader stages support subgroup operations</comment></member>
+ <member noautovalidity="true"><type>VkSubgroupFeatureFlags</type> <name>supportedOperations</name><comment>Bitfield of what subgroup operations are supported.</comment></member>
+ <member noautovalidity="true"><type>VkBool32</type> <name>quadOperationsInAllStages</name><comment>Flag to specify whether quad operations are available in all stages.</comment></member>
+ </type>
+ <type category="struct" name="VkBufferMemoryRequirementsInfo2">
+ <member values="VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBuffer</type> <name>buffer</name></member>
+ </type>
+ <type category="struct" name="VkBufferMemoryRequirementsInfo2KHR" alias="VkBufferMemoryRequirementsInfo2"/>
+ <type category="struct" name="VkImageMemoryRequirementsInfo2">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkImage</type> <name>image</name></member>
+ </type>
+ <type category="struct" name="VkImageMemoryRequirementsInfo2KHR" alias="VkImageMemoryRequirementsInfo2"/>
+ <type category="struct" name="VkImageSparseMemoryRequirementsInfo2">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkImage</type> <name>image</name></member>
+ </type>
+ <type category="struct" name="VkImageSparseMemoryRequirementsInfo2KHR" alias="VkImageSparseMemoryRequirementsInfo2"/>
+ <type category="struct" name="VkMemoryRequirements2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkMemoryRequirements</type> <name>memoryRequirements</name></member>
+ </type>
+ <type category="struct" name="VkMemoryRequirements2KHR" alias="VkMemoryRequirements2"/>
+ <type category="struct" name="VkSparseImageMemoryRequirements2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkSparseImageMemoryRequirements</type> <name>memoryRequirements</name></member>
+ </type>
+ <type category="struct" name="VkSparseImageMemoryRequirements2KHR" alias="VkSparseImageMemoryRequirements2"/>
+ <type category="struct" name="VkPhysicalDevicePointClippingProperties" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkPointClippingBehavior</type> <name>pointClippingBehavior</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDevicePointClippingPropertiesKHR" alias="VkPhysicalDevicePointClippingProperties"/>
+ <type category="struct" name="VkMemoryDedicatedRequirements" returnedonly="true" structextends="VkMemoryRequirements2">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>prefersDedicatedAllocation</name></member>
+ <member><type>VkBool32</type> <name>requiresDedicatedAllocation</name></member>
+ </type>
+ <type category="struct" name="VkMemoryDedicatedRequirementsKHR" alias="VkMemoryDedicatedRequirements"/>
+ <type category="struct" name="VkMemoryDedicatedAllocateInfo" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkImage</type> <name>image</name><comment>Image that this allocation will be bound to</comment></member>
+ <member optional="true"><type>VkBuffer</type> <name>buffer</name><comment>Buffer that this allocation will be bound to</comment></member>
+ </type>
+ <type category="struct" name="VkMemoryDedicatedAllocateInfoKHR" alias="VkMemoryDedicatedAllocateInfo"/>
+ <type category="struct" name="VkImageViewUsageCreateInfo" structextends="VkImageViewCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkImageUsageFlags</type> <name>usage</name></member>
+ </type>
+ <type category="struct" name="VkImageViewUsageCreateInfoKHR" alias="VkImageViewUsageCreateInfo"/>
+ <type category="struct" name="VkPipelineTessellationDomainOriginStateCreateInfo" structextends="VkPipelineTessellationStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkTessellationDomainOrigin</type> <name>domainOrigin</name></member>
+ </type>
+ <type category="struct" name="VkPipelineTessellationDomainOriginStateCreateInfoKHR" alias="VkPipelineTessellationDomainOriginStateCreateInfo"/>
+ <type category="struct" name="VkSamplerYcbcrConversionInfo" structextends="VkSamplerCreateInfo,VkImageViewCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkSamplerYcbcrConversion</type> <name>conversion</name></member>
+ </type>
+ <type category="struct" name="VkSamplerYcbcrConversionInfoKHR" alias="VkSamplerYcbcrConversionInfo"/>
+ <type category="struct" name="VkSamplerYcbcrConversionCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>VkSamplerYcbcrModelConversion</type> <name>ycbcrModel</name></member>
+ <member><type>VkSamplerYcbcrRange</type> <name>ycbcrRange</name></member>
+ <member><type>VkComponentMapping</type> <name>components</name></member>
+ <member><type>VkChromaLocation</type> <name>xChromaOffset</name></member>
+ <member><type>VkChromaLocation</type> <name>yChromaOffset</name></member>
+ <member><type>VkFilter</type> <name>chromaFilter</name></member>
+ <member><type>VkBool32</type> <name>forceExplicitReconstruction</name></member>
+ </type>
+ <type category="struct" name="VkSamplerYcbcrConversionCreateInfoKHR" alias="VkSamplerYcbcrConversionCreateInfo"/>
+ <type category="struct" name="VkBindImagePlaneMemoryInfo" structextends="VkBindImageMemoryInfo">
+ <member values="VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkImageAspectFlagBits</type> <name>planeAspect</name></member>
+ </type>
+ <type category="struct" name="VkBindImagePlaneMemoryInfoKHR" alias="VkBindImagePlaneMemoryInfo"/>
+ <type category="struct" name="VkImagePlaneMemoryRequirementsInfo" structextends="VkImageMemoryRequirementsInfo2">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkImageAspectFlagBits</type> <name>planeAspect</name></member>
+ </type>
+ <type category="struct" name="VkImagePlaneMemoryRequirementsInfoKHR" alias="VkImagePlaneMemoryRequirementsInfo"/>
+ <type category="struct" name="VkPhysicalDeviceSamplerYcbcrConversionFeatures" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>samplerYcbcrConversion</name><comment>Sampler color conversion supported</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceSamplerYcbcrConversionFeaturesKHR" alias="VkPhysicalDeviceSamplerYcbcrConversionFeatures"/>
+ <type category="struct" name="VkSamplerYcbcrConversionImageFormatProperties" returnedonly="true" structextends="VkImageFormatProperties2">
+ <member values="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>combinedImageSamplerDescriptorCount</name></member>
+ </type>
+ <type category="struct" name="VkSamplerYcbcrConversionImageFormatPropertiesKHR" alias="VkSamplerYcbcrConversionImageFormatProperties"/>
+ <type category="struct" name="VkTextureLODGatherFormatPropertiesAMD" returnedonly="true" structextends="VkImageFormatProperties2">
+ <member values="VK_STRUCTURE_TYPE_TEXTURE_LOD_GATHER_FORMAT_PROPERTIES_AMD"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>supportsTextureGatherLODBiasAMD</name></member>
+ </type>
+ <type category="struct" name="VkProtectedSubmitInfo" structextends="VkSubmitInfo">
+ <member values="VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>protectedSubmit</name><comment>Submit protected command buffers</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceProtectedMemoryFeatures" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>protectedMemory</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceProtectedMemoryProperties" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>protectedNoFault</name></member>
+ </type>
+ <type category="struct" name="VkDeviceQueueInfo2">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceQueueCreateFlags</type> <name>flags</name></member>
+ <member><type>uint32_t</type> <name>queueFamilyIndex</name></member>
+ <member><type>uint32_t</type> <name>queueIndex</name></member>
+ </type>
+ <type category="struct" name="VkPipelineCoverageToColorStateCreateInfoNV" structextends="VkPipelineMultisampleStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineCoverageToColorStateCreateFlagsNV</type> <name>flags</name></member>
+ <member><type>VkBool32</type> <name>coverageToColorEnable</name></member>
+ <member optional="true"><type>uint32_t</type> <name>coverageToColorLocation</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>filterMinmaxSingleComponentFormats</name></member>
+ <member><type>VkBool32</type> <name>filterMinmaxImageComponentMapping</name></member>
+ </type>
+ <type category="struct" name="VkSampleLocationEXT">
+ <member><type>float</type> <name>x</name></member>
+ <member><type>float</type> <name>y</name></member>
+ </type>
+ <type category="struct" name="VkSampleLocationsInfoEXT" structextends="VkImageMemoryBarrier">
+ <member values="VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkSampleCountFlagBits</type> <name>sampleLocationsPerPixel</name></member>
+ <member><type>VkExtent2D</type> <name>sampleLocationGridSize</name></member>
+ <member><type>uint32_t</type> <name>sampleLocationsCount</name></member>
+ <member len="sampleLocationsCount">const <type>VkSampleLocationEXT</type>* <name>pSampleLocations</name></member>
+ </type>
+ <type category="struct" name="VkAttachmentSampleLocationsEXT">
+ <member><type>uint32_t</type> <name>attachmentIndex</name></member>
+ <member><type>VkSampleLocationsInfoEXT</type> <name>sampleLocationsInfo</name></member>
+ </type>
+ <type category="struct" name="VkSubpassSampleLocationsEXT">
+ <member><type>uint32_t</type> <name>subpassIndex</name></member>
+ <member><type>VkSampleLocationsInfoEXT</type> <name>sampleLocationsInfo</name></member>
+ </type>
+ <type category="struct" name="VkRenderPassSampleLocationsBeginInfoEXT" structextends="VkRenderPassBeginInfo">
+ <member values="VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>attachmentInitialSampleLocationsCount</name></member>
+ <member len="attachmentInitialSampleLocationsCount">const <type>VkAttachmentSampleLocationsEXT</type>* <name>pAttachmentInitialSampleLocations</name></member>
+ <member optional="true"><type>uint32_t</type> <name>postSubpassSampleLocationsCount</name></member>
+ <member len="postSubpassSampleLocationsCount">const <type>VkSubpassSampleLocationsEXT</type>* <name>pPostSubpassSampleLocations</name></member>
+ </type>
+ <type category="struct" name="VkPipelineSampleLocationsStateCreateInfoEXT" structextends="VkPipelineMultisampleStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>sampleLocationsEnable</name></member>
+ <member><type>VkSampleLocationsInfoEXT</type> <name>sampleLocationsInfo</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceSampleLocationsPropertiesEXT" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkSampleCountFlags</type> <name>sampleLocationSampleCounts</name></member>
+ <member><type>VkExtent2D</type> <name>maxSampleLocationGridSize</name></member>
+ <member><type>float</type> <name>sampleLocationCoordinateRange</name>[2]</member>
+ <member><type>uint32_t</type> <name>sampleLocationSubPixelBits</name></member>
+ <member><type>VkBool32</type> <name>variableSampleLocations</name></member>
+ </type>
+ <type category="struct" name="VkMultisamplePropertiesEXT" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkExtent2D</type> <name>maxSampleLocationGridSize</name></member>
+ </type>
+ <type category="struct" name="VkSamplerReductionModeCreateInfoEXT" structextends="VkSamplerCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkSamplerReductionModeEXT</type> <name>reductionMode</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT" structextends="VkPhysicalDeviceFeatures2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>advancedBlendCoherentOperations</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>advancedBlendMaxColorAttachments</name></member>
+ <member><type>VkBool32</type> <name>advancedBlendIndependentBlend</name></member>
+ <member><type>VkBool32</type> <name>advancedBlendNonPremultipliedSrcColor</name></member>
+ <member><type>VkBool32</type> <name>advancedBlendNonPremultipliedDstColor</name></member>
+ <member><type>VkBool32</type> <name>advancedBlendCorrelatedOverlap</name></member>
+ <member><type>VkBool32</type> <name>advancedBlendAllOperations</name></member>
+ </type>
+ <type category="struct" name="VkPipelineColorBlendAdvancedStateCreateInfoEXT" structextends="VkPipelineColorBlendStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>srcPremultiplied</name></member>
+ <member><type>VkBool32</type> <name>dstPremultiplied</name></member>
+ <member><type>VkBlendOverlapEXT</type> <name>blendOverlap</name></member>
+ </type>
+ <type category="struct" name="VkPipelineCoverageModulationStateCreateInfoNV" structextends="VkPipelineMultisampleStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkPipelineCoverageModulationStateCreateFlagsNV</type> <name>flags</name></member>
+ <member><type>VkCoverageModulationModeNV</type> <name>coverageModulationMode</name></member>
+ <member><type>VkBool32</type> <name>coverageModulationTableEnable</name></member>
+ <member><type>uint32_t</type> <name>coverageModulationTableCount</name></member>
+ <member noautovalidity="true" optional="true" len="coverageModulationTableCount">const <type>float</type>* <name>pCoverageModulationTable</name></member>
+ </type>
+ <type category="struct" name="VkImageFormatListCreateInfoKHR" structextends="VkImageCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>viewFormatCount</name></member>
+ <member len="viewFormatCount">const <type>VkFormat</type>* <name>pViewFormats</name></member>
+ </type>
+ <type category="struct" name="VkValidationCacheCreateInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkValidationCacheCreateFlagsEXT</type> <name>flags</name></member>
+ <member optional="true"><type>size_t</type> <name>initialDataSize</name></member>
+ <member len="initialDataSize">const <type>void</type>* <name>pInitialData</name></member>
+ </type>
+ <type category="struct" name="VkShaderModuleValidationCacheCreateInfoEXT" structextends="VkShaderModuleCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkValidationCacheEXT</type> <name>validationCache</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMaintenance3Properties" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxPerSetDescriptors</name></member>
+ <member><type>VkDeviceSize</type> <name>maxMemoryAllocationSize</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceMaintenance3PropertiesKHR" alias="VkPhysicalDeviceMaintenance3Properties"/>
+ <type category="struct" name="VkDescriptorSetLayoutSupport" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>supported</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetLayoutSupportKHR" alias="VkDescriptorSetLayoutSupport"/>
+ <type category="struct" name="VkPhysicalDeviceShaderDrawParameterFeatures" structextends="VkPhysicalDeviceFeatures2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>shaderDrawParameters</name></member>
+ </type>
+ <type category="struct" name="VkNativeBufferANDROID">
+ <member values="VK_STRUCTURE_TYPE_NATIVE_BUFFER_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member>const <type>void</type>* <name>handle</name></member>
+ <member><type>int</type> <name>stride</name></member>
+ <member><type>int</type> <name>format</name></member>
+ <member><type>int</type> <name>usage</name></member>
+ </type>
+ <type category="struct" name="VkShaderResourceUsageAMD" returnedonly="true">
+ <member><type>uint32_t</type> <name>numUsedVgprs</name></member>
+ <member><type>uint32_t</type> <name>numUsedSgprs</name></member>
+ <member><type>uint32_t</type> <name>ldsSizePerLocalWorkGroup</name></member>
+ <member><type>size_t</type> <name>ldsUsageSizeInBytes</name></member>
+ <member><type>size_t</type> <name>scratchMemUsageInBytes</name></member>
+ </type>
+ <type category="struct" name="VkShaderStatisticsInfoAMD" returnedonly="true">
+ <member><type>VkShaderStageFlags</type> <name>shaderStageMask</name></member>
+ <member><type>VkShaderResourceUsageAMD</type> <name>resourceUsage</name></member>
+ <member><type>uint32_t</type> <name>numPhysicalVgprs</name></member>
+ <member><type>uint32_t</type> <name>numPhysicalSgprs</name></member>
+ <member><type>uint32_t</type> <name>numAvailableVgprs</name></member>
+ <member><type>uint32_t</type> <name>numAvailableSgprs</name></member>
+ <member><type>uint32_t</type> <name>computeWorkGroupSize</name>[3]</member>
+ </type>
+ <type category="struct" name="VkDeviceQueueGlobalPriorityCreateInfoEXT" structextends="VkDeviceQueueCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkQueueGlobalPriorityEXT</type> <name>globalPriority</name></member>
+ </type>
+ <type category="struct" name="VkDebugUtilsObjectNameInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkObjectType</type> <name>objectType</name></member>
+ <member><type>uint64_t</type> <name>objectHandle</name></member>
+ <member optional="true" len="null-terminated">const <type>char</type>* <name>pObjectName</name></member>
+ </type>
+ <type category="struct" name="VkDebugUtilsObjectTagInfoEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkObjectType</type> <name>objectType</name></member>
+ <member><type>uint64_t</type> <name>objectHandle</name></member>
+ <member><type>uint64_t</type> <name>tagName</name></member>
+ <member><type>size_t</type> <name>tagSize</name></member>
+ <member len="tagSize">const <type>void</type>* <name>pTag</name></member>
+ </type>
+ <type category="struct" name="VkDebugUtilsLabelEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member len="null-terminated">const <type>char</type>* <name>pLabelName</name></member>
+ <member optional="true"><type>float</type> <name>color</name>[4]</member>
+ </type>
+ <type category="struct" name="VkDebugUtilsMessengerCreateInfoEXT" structextends="VkInstanceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDebugUtilsMessengerCreateFlagsEXT</type> <name>flags</name></member>
+ <member><type>VkDebugUtilsMessageSeverityFlagsEXT</type> <name>messageSeverity</name></member>
+ <member><type>VkDebugUtilsMessageTypeFlagsEXT</type> <name>messageType</name></member>
+ <member><type>PFN_vkDebugUtilsMessengerCallbackEXT</type> <name>pfnUserCallback</name></member>
+ <member optional="true"><type>void</type>* <name>pUserData</name></member>
+ </type>
+ <type category="struct" name="VkDebugUtilsMessengerCallbackDataEXT">
+ <member values="VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member optional="true">const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>VkDebugUtilsMessengerCallbackDataFlagsEXT</type> <name>flags</name></member>
+ <member optional="true" len="null-terminated">const <type>char</type>* <name>pMessageIdName</name></member>
+ <member optional="true"><type>int32_t</type> <name>messageIdNumber</name></member>
+ <member len="null-terminated">const <type>char</type>* <name>pMessage</name></member>
+ <member optional="true"><type>uint32_t</type> <name>queueLabelCount</name></member>
+ <member noautovalidity="true" optional="true" len="queueLabelCount"><type>VkDebugUtilsLabelEXT</type>* <name>pQueueLabels</name></member>
+ <member optional="true"><type>uint32_t</type> <name>cmdBufLabelCount</name></member>
+ <member noautovalidity="true" optional="true" len="cmdBufLabelCount"><type>VkDebugUtilsLabelEXT</type>* <name>pCmdBufLabels</name></member>
+ <member><type>uint32_t</type> <name>objectCount</name></member>
+ <member noautovalidity="true" len="objectCount"><type>VkDebugUtilsObjectNameInfoEXT</type>* <name>pObjects</name></member>
+ </type>
+ <type category="struct" name="VkImportMemoryHostPointerInfoEXT" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></member>
+ <member optional="false"><type>void</type>* <name>pHostPointer</name></member>
+ </type>
+ <type category="struct" name="VkMemoryHostPointerPropertiesEXT">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>memoryTypeBits</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceExternalMemoryHostPropertiesEXT" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceSize</type> <name>minImportedHostPointerAlignment</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceConservativeRasterizationPropertiesEXT" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name><comment>Pointer to next structure</comment></member>
+ <member><type>float</type> <name>primitiveOverestimationSize</name><comment>The size in pixels the primitive is enlarged at each edge during conservative rasterization</comment></member>
+ <member><type>float</type> <name>maxExtraPrimitiveOverestimationSize</name><comment>The maximum additional overestimation the client can specify in the pipeline state</comment></member>
+ <member><type>float</type> <name>extraPrimitiveOverestimationSizeGranularity</name><comment>The granularity of extra overestimation sizes the implementations supports between 0 and maxExtraOverestimationSize</comment></member>
+ <member><type>VkBool32</type> <name>primitiveUnderestimation</name><comment>true if the implementation supports conservative rasterization underestimation mode</comment></member>
+ <member><type>VkBool32</type> <name>conservativePointAndLineRasterization</name><comment>true if conservative rasterization also applies to points and lines</comment></member>
+ <member><type>VkBool32</type> <name>degenerateTrianglesRasterized</name><comment>true if degenerate triangles (those with zero area after snap) are rasterized</comment></member>
+ <member><type>VkBool32</type> <name>degenerateLinesRasterized</name><comment>true if degenerate lines (those with zero length after snap) are rasterized</comment></member>
+ <member><type>VkBool32</type> <name>fullyCoveredFragmentShaderInputVariable</name><comment>true if the implementation supports the FullyCoveredEXT SPIR-V builtin fragment shader input variable</comment></member>
+ <member><type>VkBool32</type> <name>conservativeRasterizationPostDepthCoverage</name><comment>true if the implementation supports both conservative rasterization and post depth coverage sample coverage mask</comment></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceShaderCorePropertiesAMD" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_CORE_PROPERTIES_AMD"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name><comment>Pointer to next structure</comment></member>
+ <member><type>uint32_t</type> <name>shaderEngineCount</name><comment>number of shader engines</comment></member>
+ <member><type>uint32_t</type> <name>shaderArraysPerEngineCount</name><comment>number of shader arrays</comment></member>
+ <member><type>uint32_t</type> <name>computeUnitsPerShaderArray</name><comment>number of CUs per shader array</comment></member>
+ <member><type>uint32_t</type> <name>simdPerComputeUnit</name><comment>number of SIMDs per compute unit</comment></member>
+ <member><type>uint32_t</type> <name>wavefrontsPerSimd</name><comment>number of wavefront slots in each SIMD</comment></member>
+ <member><type>uint32_t</type> <name>wavefrontSize</name><comment>number of threads per wavefront</comment></member>
+ <member><type>uint32_t</type> <name>sgprsPerSimd</name><comment>number of physical SGPRs per SIMD</comment></member>
+ <member><type>uint32_t</type> <name>minSgprAllocation</name><comment>minimum number of SGPRs that can be allocated by a wave</comment></member>
+ <member><type>uint32_t</type> <name>maxSgprAllocation</name><comment>number of available SGPRs</comment></member>
+ <member><type>uint32_t</type> <name>sgprAllocationGranularity</name><comment>SGPRs are allocated in groups of this size</comment></member>
+ <member><type>uint32_t</type> <name>vgprsPerSimd</name><comment>number of physical VGPRs per SIMD</comment></member>
+ <member><type>uint32_t</type> <name>minVgprAllocation</name><comment>minimum number of VGPRs that can be allocated by a wave</comment></member>
+ <member><type>uint32_t</type> <name>maxVgprAllocation</name><comment>number of available VGPRs</comment></member>
+ <member><type>uint32_t</type> <name>vgprAllocationGranularity</name><comment>VGPRs are allocated in groups of this size</comment></member>
+ </type>
+ <type category="struct" name="VkPipelineRasterizationConservativeStateCreateInfoEXT" structextends="VkPipelineRasterizationStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member> <!-- Pointer to next structure -->
+ <member optional="true"><type>VkPipelineRasterizationConservativeStateCreateFlagsEXT</type> <name>flags</name></member> <!-- Reserved -->
+ <member><type>VkConservativeRasterizationModeEXT</type> <name>conservativeRasterizationMode</name></member> <!-- Conservative rasterization mode -->
+ <member><type>float</type> <name>extraPrimitiveOverestimationSize</name></member> <!-- Extra overestimation to add to the primitive -->
+ </type>
+ <type category="struct" name="VkPhysicalDeviceDescriptorIndexingFeaturesEXT" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_FEATURES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>VkBool32</type> <name>shaderInputAttachmentArrayDynamicIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderUniformTexelBufferArrayDynamicIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderStorageTexelBufferArrayDynamicIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderUniformBufferArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderSampledImageArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderStorageBufferArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderInputAttachmentArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderUniformTexelBufferArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>shaderStorageTexelBufferArrayNonUniformIndexing</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingUniformBufferUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingSampledImageUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingStorageImageUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingStorageBufferUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingUniformTexelBufferUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingStorageTexelBufferUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingUpdateUnusedWhilePending</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingPartiallyBound</name></member>
+ <member><type>VkBool32</type> <name>descriptorBindingVariableDescriptorCount</name></member>
+ <member><type>VkBool32</type> <name>runtimeDescriptorArray</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceDescriptorIndexingPropertiesEXT" returnedonly="true" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member noautovalidity="true"><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxUpdateAfterBindDescriptorsInAllPools</name></member>
+ <member><type>VkBool32</type> <name>shaderUniformBufferArrayNonUniformIndexingNative</name></member>
+ <member><type>VkBool32</type> <name>shaderSampledImageArrayNonUniformIndexingNative</name></member>
+ <member><type>VkBool32</type> <name>shaderStorageBufferArrayNonUniformIndexingNative</name></member>
+ <member><type>VkBool32</type> <name>shaderStorageImageArrayNonUniformIndexingNative</name></member>
+ <member><type>VkBool32</type> <name>shaderInputAttachmentArrayNonUniformIndexingNative</name></member>
+ <member><type>VkBool32</type> <name>robustBufferAccessUpdateAfterBind</name></member>
+ <member><type>VkBool32</type> <name>quadDivergentImplicitLod</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUpdateAfterBindSamplers</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUpdateAfterBindUniformBuffers</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUpdateAfterBindStorageBuffers</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUpdateAfterBindSampledImages</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUpdateAfterBindStorageImages</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageDescriptorUpdateAfterBindInputAttachments</name></member>
+ <member><type>uint32_t</type> <name>maxPerStageUpdateAfterBindResources</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindSamplers</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindUniformBuffers</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindUniformBuffersDynamic</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindStorageBuffers</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindStorageBuffersDynamic</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindSampledImages</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindStorageImages</name></member>
+ <member><type>uint32_t</type> <name>maxDescriptorSetUpdateAfterBindInputAttachments</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetLayoutBindingFlagsCreateInfoEXT" structextends="VkDescriptorSetLayoutCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_BINDING_FLAGS_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>bindingCount</name></member>
+ <member len="bindingCount">const <type>VkDescriptorBindingFlagsEXT</type>* <name>pBindingFlags</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetVariableDescriptorCountAllocateInfoEXT" structextends="VkDescriptorSetAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_ALLOCATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member optional="true"><type>uint32_t</type> <name>descriptorSetCount</name></member>
+ <member len="descriptorSetCount">const <type>uint32_t</type>* <name>pDescriptorCounts</name></member>
+ </type>
+ <type category="struct" name="VkDescriptorSetVariableDescriptorCountLayoutSupportEXT" structextends="VkDescriptorSetLayoutSupport" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_LAYOUT_SUPPORT_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxVariableDescriptorCount</name></member>
+ </type>
+ <type category="struct" name="VkVertexInputBindingDivisorDescriptionEXT">
+ <member><type>uint32_t</type> <name>binding</name></member>
+ <member><type>uint32_t</type> <name>divisor</name></member>
+ </type>
+ <type category="struct" name="VkPipelineVertexInputDivisorStateCreateInfoEXT" structextends="VkPipelineVertexInputStateCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>vertexBindingDivisorCount</name></member>
+ <member len="vertexBindingDivisorCount">const <type>VkVertexInputBindingDivisorDescriptionEXT</type>* <name>pVertexBindingDivisors</name></member>
+ </type>
+ <type category="struct" name="VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT" structextends="VkPhysicalDeviceProperties2">
+ <member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint32_t</type> <name>maxVertexAttribDivisor</name><comment>max value of vertex attribute divisor</comment></member>
+ </type>
+ <type category="struct" name="VkImportAndroidHardwareBufferInfoANDROID" structextends="VkMemoryAllocateInfo">
+ <member values="VK_STRUCTURE_TYPE_IMPORT_ANDROID_HARDWARE_BUFFER_INFO_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member>struct <type>AHardwareBuffer</type>* <name>buffer</name></member>
+ </type>
+ <type category="struct" name="VkAndroidHardwareBufferUsageANDROID" structextends="VkImageFormatProperties2" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_USAGE_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint64_t</type> <name>androidHardwareBufferUsage</name></member>
+ </type>
+ <type category="struct" name="VkAndroidHardwareBufferPropertiesANDROID" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_PROPERTIES_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceSize</type> <name>allocationSize</name></member>
+ <member><type>uint32_t</type> <name>memoryTypeBits</name></member>
+ </type>
+ <type category="struct" name="VkMemoryGetAndroidHardwareBufferInfoANDROID">
+ <member values="VK_STRUCTURE_TYPE_MEMORY_GET_ANDROID_HARDWARE_BUFFER_INFO_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member>const <type>void</type>* <name>pNext</name></member>
+ <member><type>VkDeviceMemory</type> <name>memory</name></member>
+ </type>
+ <type category="struct" name="VkAndroidHardwareBufferFormatPropertiesANDROID" structextends="VkAndroidHardwareBufferPropertiesANDROID" returnedonly="true">
+ <member values="VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_FORMAT_PROPERTIES_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>VkFormat</type> <name>format</name></member>
+ <member><type>uint64_t</type> <name>externalFormat</name></member>
+ <member><type>VkFormatFeatureFlags</type> <name>formatFeatures</name></member>
+ <member><type>VkComponentMapping</type> <name>samplerYcbcrConversionComponents</name></member>
+ <member><type>VkSamplerYcbcrModelConversion</type> <name>suggestedYcbcrModel</name></member>
+ <member><type>VkSamplerYcbcrRange</type> <name>suggestedYcbcrRange</name></member>
+ <member><type>VkChromaLocation</type> <name>suggestedXChromaOffset</name></member>
+ <member><type>VkChromaLocation</type> <name>suggestedYChromaOffset</name></member>
+ </type>
+ <type category="struct" name="VkExternalFormatANDROID" structextends="VkImageCreateInfo,VkSamplerYcbcrConversionCreateInfo">
+ <member values="VK_STRUCTURE_TYPE_EXTERNAL_FORMAT_ANDROID"><type>VkStructureType</type> <name>sType</name></member>
+ <member><type>void</type>* <name>pNext</name></member>
+ <member><type>uint64_t</type> <name>externalFormat</name></member>
+ </type>
+ </types>
+
+ <comment>Vulkan enumerant (token) definitions</comment>
+
+ <enums name="API Constants" comment="Vulkan hardcoded constants - not an enumerated type, part of the header boilerplate">
+ <enum value="256" name="VK_MAX_PHYSICAL_DEVICE_NAME_SIZE"/>
+ <enum value="16" name="VK_UUID_SIZE"/>
+ <enum value="8" name="VK_LUID_SIZE"/>
+ <enum name="VK_LUID_SIZE_KHR" alias="VK_LUID_SIZE"/>
+ <enum value="256" name="VK_MAX_EXTENSION_NAME_SIZE"/>
+ <enum value="256" name="VK_MAX_DESCRIPTION_SIZE"/>
+ <enum value="32" name="VK_MAX_MEMORY_TYPES"/>
+ <enum value="16" name="VK_MAX_MEMORY_HEAPS" comment="The maximum number of unique memory heaps, each of which supporting 1 or more memory types"/>
+ <enum value="1000.0f" name="VK_LOD_CLAMP_NONE"/>
+ <enum value="(~0U)" name="VK_REMAINING_MIP_LEVELS"/>
+ <enum value="(~0U)" name="VK_REMAINING_ARRAY_LAYERS"/>
+ <enum value="(~0ULL)" name="VK_WHOLE_SIZE"/>
+ <enum value="(~0U)" name="VK_ATTACHMENT_UNUSED"/>
+ <enum value="1" name="VK_TRUE"/>
+ <enum value="0" name="VK_FALSE"/>
+ <enum value="(~0U)" name="VK_QUEUE_FAMILY_IGNORED"/>
+ <enum value="(~0U-1)" name="VK_QUEUE_FAMILY_EXTERNAL"/>
+ <enum name="VK_QUEUE_FAMILY_EXTERNAL_KHR" alias="VK_QUEUE_FAMILY_EXTERNAL"/>
+ <enum value="(~0U-2)" name="VK_QUEUE_FAMILY_FOREIGN_EXT"/>
+ <enum value="(~0U)" name="VK_SUBPASS_EXTERNAL"/>
+ <enum value="32" name="VK_MAX_DEVICE_GROUP_SIZE"/>
+ <enum name="VK_MAX_DEVICE_GROUP_SIZE_KHR" alias="VK_MAX_DEVICE_GROUP_SIZE"/>
+ </enums>
+
+ <comment>
+ Unlike OpenGL, most tokens in Vulkan are actual typed enumerants in
+ their own numeric namespaces. The "name" attribute is the C enum
+ type name, and is pulled in from a type tag definition above
+ (slightly clunky, but retains the type / enum distinction). "type"
+ attributes of "enum" or "bitmask" indicate that these values should
+ be generated inside an appropriate definition.
+ </comment>
+
+ <enums name="VkImageLayout" type="enum">
+ <enum value="0" name="VK_IMAGE_LAYOUT_UNDEFINED" comment="Implicit layout an image is when its contents are undefined due to various reasons (e.g. right after creation)"/>
+ <enum value="1" name="VK_IMAGE_LAYOUT_GENERAL" comment="General layout when image can be used for any kind of access"/>
+ <enum value="2" name="VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL" comment="Optimal layout when image is only used for color attachment read/write"/>
+ <enum value="3" name="VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL" comment="Optimal layout when image is only used for depth/stencil attachment read/write"/>
+ <enum value="4" name="VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL" comment="Optimal layout when image is used for read only depth/stencil attachment and shader access"/>
+ <enum value="5" name="VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL" comment="Optimal layout when image is used for read only shader access"/>
+ <enum value="6" name="VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL" comment="Optimal layout when image is used only as source of transfer operations"/>
+ <enum value="7" name="VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL" comment="Optimal layout when image is used only as destination of transfer operations"/>
+ <enum value="8" name="VK_IMAGE_LAYOUT_PREINITIALIZED" comment="Initial layout used when the data is populated by the CPU"/>
+ </enums>
+ <enums name="VkAttachmentLoadOp" type="enum">
+ <enum value="0" name="VK_ATTACHMENT_LOAD_OP_LOAD"/>
+ <enum value="1" name="VK_ATTACHMENT_LOAD_OP_CLEAR"/>
+ <enum value="2" name="VK_ATTACHMENT_LOAD_OP_DONT_CARE"/>
+ </enums>
+ <enums name="VkAttachmentStoreOp" type="enum">
+ <enum value="0" name="VK_ATTACHMENT_STORE_OP_STORE"/>
+ <enum value="1" name="VK_ATTACHMENT_STORE_OP_DONT_CARE"/>
+ </enums>
+ <enums name="VkImageType" type="enum">
+ <enum value="0" name="VK_IMAGE_TYPE_1D"/>
+ <enum value="1" name="VK_IMAGE_TYPE_2D"/>
+ <enum value="2" name="VK_IMAGE_TYPE_3D"/>
+ </enums>
+ <enums name="VkImageTiling" type="enum">
+ <enum value="0" name="VK_IMAGE_TILING_OPTIMAL"/>
+ <enum value="1" name="VK_IMAGE_TILING_LINEAR"/>
+ </enums>
+ <enums name="VkImageViewType" type="enum">
+ <enum value="0" name="VK_IMAGE_VIEW_TYPE_1D"/>
+ <enum value="1" name="VK_IMAGE_VIEW_TYPE_2D"/>
+ <enum value="2" name="VK_IMAGE_VIEW_TYPE_3D"/>
+ <enum value="3" name="VK_IMAGE_VIEW_TYPE_CUBE"/>
+ <enum value="4" name="VK_IMAGE_VIEW_TYPE_1D_ARRAY"/>
+ <enum value="5" name="VK_IMAGE_VIEW_TYPE_2D_ARRAY"/>
+ <enum value="6" name="VK_IMAGE_VIEW_TYPE_CUBE_ARRAY"/>
+ </enums>
+ <enums name="VkCommandBufferLevel" type="enum">
+ <enum value="0" name="VK_COMMAND_BUFFER_LEVEL_PRIMARY"/>
+ <enum value="1" name="VK_COMMAND_BUFFER_LEVEL_SECONDARY"/>
+ </enums>
+ <enums name="VkComponentSwizzle" type="enum">
+ <enum value="0" name="VK_COMPONENT_SWIZZLE_IDENTITY"/>
+ <enum value="1" name="VK_COMPONENT_SWIZZLE_ZERO"/>
+ <enum value="2" name="VK_COMPONENT_SWIZZLE_ONE"/>
+ <enum value="3" name="VK_COMPONENT_SWIZZLE_R"/>
+ <enum value="4" name="VK_COMPONENT_SWIZZLE_G"/>
+ <enum value="5" name="VK_COMPONENT_SWIZZLE_B"/>
+ <enum value="6" name="VK_COMPONENT_SWIZZLE_A"/>
+ </enums>
+ <enums name="VkDescriptorType" type="enum">
+ <enum value="0" name="VK_DESCRIPTOR_TYPE_SAMPLER"/>
+ <enum value="1" name="VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER"/>
+ <enum value="2" name="VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE"/>
+ <enum value="3" name="VK_DESCRIPTOR_TYPE_STORAGE_IMAGE"/>
+ <enum value="4" name="VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER"/>
+ <enum value="5" name="VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER"/>
+ <enum value="6" name="VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER"/>
+ <enum value="7" name="VK_DESCRIPTOR_TYPE_STORAGE_BUFFER"/>
+ <enum value="8" name="VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC"/>
+ <enum value="9" name="VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC"/>
+ <enum value="10" name="VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT"/>
+ </enums>
+ <enums name="VkQueryType" type="enum">
+ <enum value="0" name="VK_QUERY_TYPE_OCCLUSION"/>
+ <enum value="1" name="VK_QUERY_TYPE_PIPELINE_STATISTICS" comment="Optional"/>
+ <enum value="2" name="VK_QUERY_TYPE_TIMESTAMP"/>
+ </enums>
+ <enums name="VkBorderColor" type="enum">
+ <enum value="0" name="VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK"/>
+ <enum value="1" name="VK_BORDER_COLOR_INT_TRANSPARENT_BLACK"/>
+ <enum value="2" name="VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK"/>
+ <enum value="3" name="VK_BORDER_COLOR_INT_OPAQUE_BLACK"/>
+ <enum value="4" name="VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE"/>
+ <enum value="5" name="VK_BORDER_COLOR_INT_OPAQUE_WHITE"/>
+ </enums>
+ <enums name="VkPipelineBindPoint" type="enum">
+ <enum value="0" name="VK_PIPELINE_BIND_POINT_GRAPHICS"/>
+ <enum value="1" name="VK_PIPELINE_BIND_POINT_COMPUTE"/>
+ </enums>
+ <enums name="VkPipelineCacheHeaderVersion" type="enum">
+ <enum value="1" name="VK_PIPELINE_CACHE_HEADER_VERSION_ONE"/>
+ </enums>
+ <enums name="VkPrimitiveTopology" type="enum">
+ <enum value="0" name="VK_PRIMITIVE_TOPOLOGY_POINT_LIST"/>
+ <enum value="1" name="VK_PRIMITIVE_TOPOLOGY_LINE_LIST"/>
+ <enum value="2" name="VK_PRIMITIVE_TOPOLOGY_LINE_STRIP"/>
+ <enum value="3" name="VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST"/>
+ <enum value="4" name="VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP"/>
+ <enum value="5" name="VK_PRIMITIVE_TOPOLOGY_TRIANGLE_FAN"/>
+ <enum value="6" name="VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY"/>
+ <enum value="7" name="VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY"/>
+ <enum value="8" name="VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY"/>
+ <enum value="9" name="VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY"/>
+ <enum value="10" name="VK_PRIMITIVE_TOPOLOGY_PATCH_LIST"/>
+ </enums>
+ <enums name="VkSharingMode" type="enum">
+ <enum value="0" name="VK_SHARING_MODE_EXCLUSIVE"/>
+ <enum value="1" name="VK_SHARING_MODE_CONCURRENT"/>
+ </enums>
+ <enums name="VkIndexType" type="enum">
+ <enum value="0" name="VK_INDEX_TYPE_UINT16"/>
+ <enum value="1" name="VK_INDEX_TYPE_UINT32"/>
+ </enums>
+ <enums name="VkFilter" type="enum">
+ <enum value="0" name="VK_FILTER_NEAREST"/>
+ <enum value="1" name="VK_FILTER_LINEAR"/>
+ </enums>
+ <enums name="VkSamplerMipmapMode" type="enum">
+ <enum value="0" name="VK_SAMPLER_MIPMAP_MODE_NEAREST" comment="Choose nearest mip level"/>
+ <enum value="1" name="VK_SAMPLER_MIPMAP_MODE_LINEAR" comment="Linear filter between mip levels"/>
+ </enums>
+ <enums name="VkSamplerAddressMode" type="enum">
+ <enum value="0" name="VK_SAMPLER_ADDRESS_MODE_REPEAT"/>
+ <enum value="1" name="VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT"/>
+ <enum value="2" name="VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE"/>
+ <enum value="3" name="VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER"/>
+ <comment>
+ value="4" reserved for VK_KHR_sampler_mirror_clamp_to_edge
+ enum VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE; do not
+ alias!
+ </comment>
+ </enums>
+ <enums name="VkCompareOp" type="enum">
+ <enum value="0" name="VK_COMPARE_OP_NEVER"/>
+ <enum value="1" name="VK_COMPARE_OP_LESS"/>
+ <enum value="2" name="VK_COMPARE_OP_EQUAL"/>
+ <enum value="3" name="VK_COMPARE_OP_LESS_OR_EQUAL"/>
+ <enum value="4" name="VK_COMPARE_OP_GREATER"/>
+ <enum value="5" name="VK_COMPARE_OP_NOT_EQUAL"/>
+ <enum value="6" name="VK_COMPARE_OP_GREATER_OR_EQUAL"/>
+ <enum value="7" name="VK_COMPARE_OP_ALWAYS"/>
+ </enums>
+ <enums name="VkPolygonMode" type="enum">
+ <enum value="0" name="VK_POLYGON_MODE_FILL"/>
+ <enum value="1" name="VK_POLYGON_MODE_LINE"/>
+ <enum value="2" name="VK_POLYGON_MODE_POINT"/>
+ </enums>
+ <enums name="VkCullModeFlagBits" type="bitmask">
+ <enum value="0" name="VK_CULL_MODE_NONE"/>
+ <enum bitpos="0" name="VK_CULL_MODE_FRONT_BIT"/>
+ <enum bitpos="1" name="VK_CULL_MODE_BACK_BIT"/>
+ <enum value="0x00000003" name="VK_CULL_MODE_FRONT_AND_BACK"/>
+ </enums>
+ <enums name="VkFrontFace" type="enum">
+ <enum value="0" name="VK_FRONT_FACE_COUNTER_CLOCKWISE"/>
+ <enum value="1" name="VK_FRONT_FACE_CLOCKWISE"/>
+ </enums>
+ <enums name="VkBlendFactor" type="enum">
+ <enum value="0" name="VK_BLEND_FACTOR_ZERO"/>
+ <enum value="1" name="VK_BLEND_FACTOR_ONE"/>
+ <enum value="2" name="VK_BLEND_FACTOR_SRC_COLOR"/>
+ <enum value="3" name="VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR"/>
+ <enum value="4" name="VK_BLEND_FACTOR_DST_COLOR"/>
+ <enum value="5" name="VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR"/>
+ <enum value="6" name="VK_BLEND_FACTOR_SRC_ALPHA"/>
+ <enum value="7" name="VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA"/>
+ <enum value="8" name="VK_BLEND_FACTOR_DST_ALPHA"/>
+ <enum value="9" name="VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA"/>
+ <enum value="10" name="VK_BLEND_FACTOR_CONSTANT_COLOR"/>
+ <enum value="11" name="VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COLOR"/>
+ <enum value="12" name="VK_BLEND_FACTOR_CONSTANT_ALPHA"/>
+ <enum value="13" name="VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_ALPHA"/>
+ <enum value="14" name="VK_BLEND_FACTOR_SRC_ALPHA_SATURATE"/>
+ <enum value="15" name="VK_BLEND_FACTOR_SRC1_COLOR"/>
+ <enum value="16" name="VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR"/>
+ <enum value="17" name="VK_BLEND_FACTOR_SRC1_ALPHA"/>
+ <enum value="18" name="VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA"/>
+ </enums>
+ <enums name="VkBlendOp" type="enum">
+ <enum value="0" name="VK_BLEND_OP_ADD"/>
+ <enum value="1" name="VK_BLEND_OP_SUBTRACT"/>
+ <enum value="2" name="VK_BLEND_OP_REVERSE_SUBTRACT"/>
+ <enum value="3" name="VK_BLEND_OP_MIN"/>
+ <enum value="4" name="VK_BLEND_OP_MAX"/>
+ </enums>
+ <enums name="VkStencilOp" type="enum">
+ <enum value="0" name="VK_STENCIL_OP_KEEP"/>
+ <enum value="1" name="VK_STENCIL_OP_ZERO"/>
+ <enum value="2" name="VK_STENCIL_OP_REPLACE"/>
+ <enum value="3" name="VK_STENCIL_OP_INCREMENT_AND_CLAMP"/>
+ <enum value="4" name="VK_STENCIL_OP_DECREMENT_AND_CLAMP"/>
+ <enum value="5" name="VK_STENCIL_OP_INVERT"/>
+ <enum value="6" name="VK_STENCIL_OP_INCREMENT_AND_WRAP"/>
+ <enum value="7" name="VK_STENCIL_OP_DECREMENT_AND_WRAP"/>
+ </enums>
+ <enums name="VkLogicOp" type="enum">
+ <enum value="0" name="VK_LOGIC_OP_CLEAR"/>
+ <enum value="1" name="VK_LOGIC_OP_AND"/>
+ <enum value="2" name="VK_LOGIC_OP_AND_REVERSE"/>
+ <enum value="3" name="VK_LOGIC_OP_COPY"/>
+ <enum value="4" name="VK_LOGIC_OP_AND_INVERTED"/>
+ <enum value="5" name="VK_LOGIC_OP_NO_OP"/>
+ <enum value="6" name="VK_LOGIC_OP_XOR"/>
+ <enum value="7" name="VK_LOGIC_OP_OR"/>
+ <enum value="8" name="VK_LOGIC_OP_NOR"/>
+ <enum value="9" name="VK_LOGIC_OP_EQUIVALENT"/>
+ <enum value="10" name="VK_LOGIC_OP_INVERT"/>
+ <enum value="11" name="VK_LOGIC_OP_OR_REVERSE"/>
+ <enum value="12" name="VK_LOGIC_OP_COPY_INVERTED"/>
+ <enum value="13" name="VK_LOGIC_OP_OR_INVERTED"/>
+ <enum value="14" name="VK_LOGIC_OP_NAND"/>
+ <enum value="15" name="VK_LOGIC_OP_SET"/>
+ </enums>
+ <enums name="VkInternalAllocationType" type="enum">
+ <enum value="0" name="VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE"/>
+ </enums>
+ <enums name="VkSystemAllocationScope" type="enum">
+ <enum value="0" name="VK_SYSTEM_ALLOCATION_SCOPE_COMMAND"/>
+ <enum value="1" name="VK_SYSTEM_ALLOCATION_SCOPE_OBJECT"/>
+ <enum value="2" name="VK_SYSTEM_ALLOCATION_SCOPE_CACHE"/>
+ <enum value="3" name="VK_SYSTEM_ALLOCATION_SCOPE_DEVICE"/>
+ <enum value="4" name="VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE"/>
+ </enums>
+ <enums name="VkPhysicalDeviceType" type="enum">
+ <enum value="0" name="VK_PHYSICAL_DEVICE_TYPE_OTHER"/>
+ <enum value="1" name="VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU"/>
+ <enum value="2" name="VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU"/>
+ <enum value="3" name="VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU"/>
+ <enum value="4" name="VK_PHYSICAL_DEVICE_TYPE_CPU"/>
+ </enums>
+ <enums name="VkVertexInputRate" type="enum">
+ <enum value="0" name="VK_VERTEX_INPUT_RATE_VERTEX"/>
+ <enum value="1" name="VK_VERTEX_INPUT_RATE_INSTANCE"/>
+ </enums>
+ <enums name="VkFormat" type="enum" comment="Vulkan format definitions">
+ <enum value="0" name="VK_FORMAT_UNDEFINED"/>
+ <enum value="1" name="VK_FORMAT_R4G4_UNORM_PACK8"/>
+ <enum value="2" name="VK_FORMAT_R4G4B4A4_UNORM_PACK16"/>
+ <enum value="3" name="VK_FORMAT_B4G4R4A4_UNORM_PACK16"/>
+ <enum value="4" name="VK_FORMAT_R5G6B5_UNORM_PACK16"/>
+ <enum value="5" name="VK_FORMAT_B5G6R5_UNORM_PACK16"/>
+ <enum value="6" name="VK_FORMAT_R5G5B5A1_UNORM_PACK16"/>
+ <enum value="7" name="VK_FORMAT_B5G5R5A1_UNORM_PACK16"/>
+ <enum value="8" name="VK_FORMAT_A1R5G5B5_UNORM_PACK16"/>
+ <enum value="9" name="VK_FORMAT_R8_UNORM"/>
+ <enum value="10" name="VK_FORMAT_R8_SNORM"/>
+ <enum value="11" name="VK_FORMAT_R8_USCALED"/>
+ <enum value="12" name="VK_FORMAT_R8_SSCALED"/>
+ <enum value="13" name="VK_FORMAT_R8_UINT"/>
+ <enum value="14" name="VK_FORMAT_R8_SINT"/>
+ <enum value="15" name="VK_FORMAT_R8_SRGB"/>
+ <enum value="16" name="VK_FORMAT_R8G8_UNORM"/>
+ <enum value="17" name="VK_FORMAT_R8G8_SNORM"/>
+ <enum value="18" name="VK_FORMAT_R8G8_USCALED"/>
+ <enum value="19" name="VK_FORMAT_R8G8_SSCALED"/>
+ <enum value="20" name="VK_FORMAT_R8G8_UINT"/>
+ <enum value="21" name="VK_FORMAT_R8G8_SINT"/>
+ <enum value="22" name="VK_FORMAT_R8G8_SRGB"/>
+ <enum value="23" name="VK_FORMAT_R8G8B8_UNORM"/>
+ <enum value="24" name="VK_FORMAT_R8G8B8_SNORM"/>
+ <enum value="25" name="VK_FORMAT_R8G8B8_USCALED"/>
+ <enum value="26" name="VK_FORMAT_R8G8B8_SSCALED"/>
+ <enum value="27" name="VK_FORMAT_R8G8B8_UINT"/>
+ <enum value="28" name="VK_FORMAT_R8G8B8_SINT"/>
+ <enum value="29" name="VK_FORMAT_R8G8B8_SRGB"/>
+ <enum value="30" name="VK_FORMAT_B8G8R8_UNORM"/>
+ <enum value="31" name="VK_FORMAT_B8G8R8_SNORM"/>
+ <enum value="32" name="VK_FORMAT_B8G8R8_USCALED"/>
+ <enum value="33" name="VK_FORMAT_B8G8R8_SSCALED"/>
+ <enum value="34" name="VK_FORMAT_B8G8R8_UINT"/>
+ <enum value="35" name="VK_FORMAT_B8G8R8_SINT"/>
+ <enum value="36" name="VK_FORMAT_B8G8R8_SRGB"/>
+ <enum value="37" name="VK_FORMAT_R8G8B8A8_UNORM"/>
+ <enum value="38" name="VK_FORMAT_R8G8B8A8_SNORM"/>
+ <enum value="39" name="VK_FORMAT_R8G8B8A8_USCALED"/>
+ <enum value="40" name="VK_FORMAT_R8G8B8A8_SSCALED"/>
+ <enum value="41" name="VK_FORMAT_R8G8B8A8_UINT"/>
+ <enum value="42" name="VK_FORMAT_R8G8B8A8_SINT"/>
+ <enum value="43" name="VK_FORMAT_R8G8B8A8_SRGB"/>
+ <enum value="44" name="VK_FORMAT_B8G8R8A8_UNORM"/>
+ <enum value="45" name="VK_FORMAT_B8G8R8A8_SNORM"/>
+ <enum value="46" name="VK_FORMAT_B8G8R8A8_USCALED"/>
+ <enum value="47" name="VK_FORMAT_B8G8R8A8_SSCALED"/>
+ <enum value="48" name="VK_FORMAT_B8G8R8A8_UINT"/>
+ <enum value="49" name="VK_FORMAT_B8G8R8A8_SINT"/>
+ <enum value="50" name="VK_FORMAT_B8G8R8A8_SRGB"/>
+ <enum value="51" name="VK_FORMAT_A8B8G8R8_UNORM_PACK32"/>
+ <enum value="52" name="VK_FORMAT_A8B8G8R8_SNORM_PACK32"/>
+ <enum value="53" name="VK_FORMAT_A8B8G8R8_USCALED_PACK32"/>
+ <enum value="54" name="VK_FORMAT_A8B8G8R8_SSCALED_PACK32"/>
+ <enum value="55" name="VK_FORMAT_A8B8G8R8_UINT_PACK32"/>
+ <enum value="56" name="VK_FORMAT_A8B8G8R8_SINT_PACK32"/>
+ <enum value="57" name="VK_FORMAT_A8B8G8R8_SRGB_PACK32"/>
+ <enum value="58" name="VK_FORMAT_A2R10G10B10_UNORM_PACK32"/>
+ <enum value="59" name="VK_FORMAT_A2R10G10B10_SNORM_PACK32"/>
+ <enum value="60" name="VK_FORMAT_A2R10G10B10_USCALED_PACK32"/>
+ <enum value="61" name="VK_FORMAT_A2R10G10B10_SSCALED_PACK32"/>
+ <enum value="62" name="VK_FORMAT_A2R10G10B10_UINT_PACK32"/>
+ <enum value="63" name="VK_FORMAT_A2R10G10B10_SINT_PACK32"/>
+ <enum value="64" name="VK_FORMAT_A2B10G10R10_UNORM_PACK32"/>
+ <enum value="65" name="VK_FORMAT_A2B10G10R10_SNORM_PACK32"/>
+ <enum value="66" name="VK_FORMAT_A2B10G10R10_USCALED_PACK32"/>
+ <enum value="67" name="VK_FORMAT_A2B10G10R10_SSCALED_PACK32"/>
+ <enum value="68" name="VK_FORMAT_A2B10G10R10_UINT_PACK32"/>
+ <enum value="69" name="VK_FORMAT_A2B10G10R10_SINT_PACK32"/>
+ <enum value="70" name="VK_FORMAT_R16_UNORM"/>
+ <enum value="71" name="VK_FORMAT_R16_SNORM"/>
+ <enum value="72" name="VK_FORMAT_R16_USCALED"/>
+ <enum value="73" name="VK_FORMAT_R16_SSCALED"/>
+ <enum value="74" name="VK_FORMAT_R16_UINT"/>
+ <enum value="75" name="VK_FORMAT_R16_SINT"/>
+ <enum value="76" name="VK_FORMAT_R16_SFLOAT"/>
+ <enum value="77" name="VK_FORMAT_R16G16_UNORM"/>
+ <enum value="78" name="VK_FORMAT_R16G16_SNORM"/>
+ <enum value="79" name="VK_FORMAT_R16G16_USCALED"/>
+ <enum value="80" name="VK_FORMAT_R16G16_SSCALED"/>
+ <enum value="81" name="VK_FORMAT_R16G16_UINT"/>
+ <enum value="82" name="VK_FORMAT_R16G16_SINT"/>
+ <enum value="83" name="VK_FORMAT_R16G16_SFLOAT"/>
+ <enum value="84" name="VK_FORMAT_R16G16B16_UNORM"/>
+ <enum value="85" name="VK_FORMAT_R16G16B16_SNORM"/>
+ <enum value="86" name="VK_FORMAT_R16G16B16_USCALED"/>
+ <enum value="87" name="VK_FORMAT_R16G16B16_SSCALED"/>
+ <enum value="88" name="VK_FORMAT_R16G16B16_UINT"/>
+ <enum value="89" name="VK_FORMAT_R16G16B16_SINT"/>
+ <enum value="90" name="VK_FORMAT_R16G16B16_SFLOAT"/>
+ <enum value="91" name="VK_FORMAT_R16G16B16A16_UNORM"/>
+ <enum value="92" name="VK_FORMAT_R16G16B16A16_SNORM"/>
+ <enum value="93" name="VK_FORMAT_R16G16B16A16_USCALED"/>
+ <enum value="94" name="VK_FORMAT_R16G16B16A16_SSCALED"/>
+ <enum value="95" name="VK_FORMAT_R16G16B16A16_UINT"/>
+ <enum value="96" name="VK_FORMAT_R16G16B16A16_SINT"/>
+ <enum value="97" name="VK_FORMAT_R16G16B16A16_SFLOAT"/>
+ <enum value="98" name="VK_FORMAT_R32_UINT"/>
+ <enum value="99" name="VK_FORMAT_R32_SINT"/>
+ <enum value="100" name="VK_FORMAT_R32_SFLOAT"/>
+ <enum value="101" name="VK_FORMAT_R32G32_UINT"/>
+ <enum value="102" name="VK_FORMAT_R32G32_SINT"/>
+ <enum value="103" name="VK_FORMAT_R32G32_SFLOAT"/>
+ <enum value="104" name="VK_FORMAT_R32G32B32_UINT"/>
+ <enum value="105" name="VK_FORMAT_R32G32B32_SINT"/>
+ <enum value="106" name="VK_FORMAT_R32G32B32_SFLOAT"/>
+ <enum value="107" name="VK_FORMAT_R32G32B32A32_UINT"/>
+ <enum value="108" name="VK_FORMAT_R32G32B32A32_SINT"/>
+ <enum value="109" name="VK_FORMAT_R32G32B32A32_SFLOAT"/>
+ <enum value="110" name="VK_FORMAT_R64_UINT"/>
+ <enum value="111" name="VK_FORMAT_R64_SINT"/>
+ <enum value="112" name="VK_FORMAT_R64_SFLOAT"/>
+ <enum value="113" name="VK_FORMAT_R64G64_UINT"/>
+ <enum value="114" name="VK_FORMAT_R64G64_SINT"/>
+ <enum value="115" name="VK_FORMAT_R64G64_SFLOAT"/>
+ <enum value="116" name="VK_FORMAT_R64G64B64_UINT"/>
+ <enum value="117" name="VK_FORMAT_R64G64B64_SINT"/>
+ <enum value="118" name="VK_FORMAT_R64G64B64_SFLOAT"/>
+ <enum value="119" name="VK_FORMAT_R64G64B64A64_UINT"/>
+ <enum value="120" name="VK_FORMAT_R64G64B64A64_SINT"/>
+ <enum value="121" name="VK_FORMAT_R64G64B64A64_SFLOAT"/>
+ <enum value="122" name="VK_FORMAT_B10G11R11_UFLOAT_PACK32"/>
+ <enum value="123" name="VK_FORMAT_E5B9G9R9_UFLOAT_PACK32"/>
+ <enum value="124" name="VK_FORMAT_D16_UNORM"/>
+ <enum value="125" name="VK_FORMAT_X8_D24_UNORM_PACK32"/>
+ <enum value="126" name="VK_FORMAT_D32_SFLOAT"/>
+ <enum value="127" name="VK_FORMAT_S8_UINT"/>
+ <enum value="128" name="VK_FORMAT_D16_UNORM_S8_UINT"/>
+ <enum value="129" name="VK_FORMAT_D24_UNORM_S8_UINT"/>
+ <enum value="130" name="VK_FORMAT_D32_SFLOAT_S8_UINT"/>
+ <enum value="131" name="VK_FORMAT_BC1_RGB_UNORM_BLOCK"/>
+ <enum value="132" name="VK_FORMAT_BC1_RGB_SRGB_BLOCK"/>
+ <enum value="133" name="VK_FORMAT_BC1_RGBA_UNORM_BLOCK"/>
+ <enum value="134" name="VK_FORMAT_BC1_RGBA_SRGB_BLOCK"/>
+ <enum value="135" name="VK_FORMAT_BC2_UNORM_BLOCK"/>
+ <enum value="136" name="VK_FORMAT_BC2_SRGB_BLOCK"/>
+ <enum value="137" name="VK_FORMAT_BC3_UNORM_BLOCK"/>
+ <enum value="138" name="VK_FORMAT_BC3_SRGB_BLOCK"/>
+ <enum value="139" name="VK_FORMAT_BC4_UNORM_BLOCK"/>
+ <enum value="140" name="VK_FORMAT_BC4_SNORM_BLOCK"/>
+ <enum value="141" name="VK_FORMAT_BC5_UNORM_BLOCK"/>
+ <enum value="142" name="VK_FORMAT_BC5_SNORM_BLOCK"/>
+ <enum value="143" name="VK_FORMAT_BC6H_UFLOAT_BLOCK"/>
+ <enum value="144" name="VK_FORMAT_BC6H_SFLOAT_BLOCK"/>
+ <enum value="145" name="VK_FORMAT_BC7_UNORM_BLOCK"/>
+ <enum value="146" name="VK_FORMAT_BC7_SRGB_BLOCK"/>
+ <enum value="147" name="VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK"/>
+ <enum value="148" name="VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK"/>
+ <enum value="149" name="VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK"/>
+ <enum value="150" name="VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK"/>
+ <enum value="151" name="VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK"/>
+ <enum value="152" name="VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK"/>
+ <enum value="153" name="VK_FORMAT_EAC_R11_UNORM_BLOCK"/>
+ <enum value="154" name="VK_FORMAT_EAC_R11_SNORM_BLOCK"/>
+ <enum value="155" name="VK_FORMAT_EAC_R11G11_UNORM_BLOCK"/>
+ <enum value="156" name="VK_FORMAT_EAC_R11G11_SNORM_BLOCK"/>
+ <enum value="157" name="VK_FORMAT_ASTC_4x4_UNORM_BLOCK"/>
+ <enum value="158" name="VK_FORMAT_ASTC_4x4_SRGB_BLOCK"/>
+ <enum value="159" name="VK_FORMAT_ASTC_5x4_UNORM_BLOCK"/>
+ <enum value="160" name="VK_FORMAT_ASTC_5x4_SRGB_BLOCK"/>
+ <enum value="161" name="VK_FORMAT_ASTC_5x5_UNORM_BLOCK"/>
+ <enum value="162" name="VK_FORMAT_ASTC_5x5_SRGB_BLOCK"/>
+ <enum value="163" name="VK_FORMAT_ASTC_6x5_UNORM_BLOCK"/>
+ <enum value="164" name="VK_FORMAT_ASTC_6x5_SRGB_BLOCK"/>
+ <enum value="165" name="VK_FORMAT_ASTC_6x6_UNORM_BLOCK"/>
+ <enum value="166" name="VK_FORMAT_ASTC_6x6_SRGB_BLOCK"/>
+ <enum value="167" name="VK_FORMAT_ASTC_8x5_UNORM_BLOCK"/>
+ <enum value="168" name="VK_FORMAT_ASTC_8x5_SRGB_BLOCK"/>
+ <enum value="169" name="VK_FORMAT_ASTC_8x6_UNORM_BLOCK"/>
+ <enum value="170" name="VK_FORMAT_ASTC_8x6_SRGB_BLOCK"/>
+ <enum value="171" name="VK_FORMAT_ASTC_8x8_UNORM_BLOCK"/>
+ <enum value="172" name="VK_FORMAT_ASTC_8x8_SRGB_BLOCK"/>
+ <enum value="173" name="VK_FORMAT_ASTC_10x5_UNORM_BLOCK"/>
+ <enum value="174" name="VK_FORMAT_ASTC_10x5_SRGB_BLOCK"/>
+ <enum value="175" name="VK_FORMAT_ASTC_10x6_UNORM_BLOCK"/>
+ <enum value="176" name="VK_FORMAT_ASTC_10x6_SRGB_BLOCK"/>
+ <enum value="177" name="VK_FORMAT_ASTC_10x8_UNORM_BLOCK"/>
+ <enum value="178" name="VK_FORMAT_ASTC_10x8_SRGB_BLOCK"/>
+ <enum value="179" name="VK_FORMAT_ASTC_10x10_UNORM_BLOCK"/>
+ <enum value="180" name="VK_FORMAT_ASTC_10x10_SRGB_BLOCK"/>
+ <enum value="181" name="VK_FORMAT_ASTC_12x10_UNORM_BLOCK"/>
+ <enum value="182" name="VK_FORMAT_ASTC_12x10_SRGB_BLOCK"/>
+ <enum value="183" name="VK_FORMAT_ASTC_12x12_UNORM_BLOCK"/>
+ <enum value="184" name="VK_FORMAT_ASTC_12x12_SRGB_BLOCK"/>
+ </enums>
+ <enums name="VkStructureType" type="enum" comment="Structure type enumerant">
+ <enum value="0" name="VK_STRUCTURE_TYPE_APPLICATION_INFO"/>
+ <enum value="1" name="VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO"/>
+ <enum value="2" name="VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO"/>
+ <enum value="3" name="VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO"/>
+ <enum value="4" name="VK_STRUCTURE_TYPE_SUBMIT_INFO"/>
+ <enum value="5" name="VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO"/>
+ <enum value="6" name="VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE"/>
+ <enum value="7" name="VK_STRUCTURE_TYPE_BIND_SPARSE_INFO"/>
+ <enum value="8" name="VK_STRUCTURE_TYPE_FENCE_CREATE_INFO"/>
+ <enum value="9" name="VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO"/>
+ <enum value="10" name="VK_STRUCTURE_TYPE_EVENT_CREATE_INFO"/>
+ <enum value="11" name="VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO"/>
+ <enum value="12" name="VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO"/>
+ <enum value="13" name="VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO"/>
+ <enum value="14" name="VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO"/>
+ <enum value="15" name="VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO"/>
+ <enum value="16" name="VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO"/>
+ <enum value="17" name="VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO"/>
+ <enum value="18" name="VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO"/>
+ <enum value="19" name="VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO"/>
+ <enum value="20" name="VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO"/>
+ <enum value="21" name="VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO"/>
+ <enum value="22" name="VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO"/>
+ <enum value="23" name="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO"/>
+ <enum value="24" name="VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO"/>
+ <enum value="25" name="VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO"/>
+ <enum value="26" name="VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO"/>
+ <enum value="27" name="VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO"/>
+ <enum value="28" name="VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO"/>
+ <enum value="29" name="VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO"/>
+ <enum value="30" name="VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO"/>
+ <enum value="31" name="VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO"/>
+ <enum value="32" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO"/>
+ <enum value="33" name="VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO"/>
+ <enum value="34" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO"/>
+ <enum value="35" name="VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET"/>
+ <enum value="36" name="VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET"/>
+ <enum value="37" name="VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO"/>
+ <enum value="38" name="VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO"/>
+ <enum value="39" name="VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO"/>
+ <enum value="40" name="VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO"/>
+ <enum value="41" name="VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO"/>
+ <enum value="42" name="VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO"/>
+ <enum value="43" name="VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO"/>
+ <enum value="44" name="VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER"/>
+ <enum value="45" name="VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER"/>
+ <enum value="46" name="VK_STRUCTURE_TYPE_MEMORY_BARRIER"/>
+ <enum value="47" name="VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO" comment="Reserved for internal use by the loader, layers, and ICDs"/>
+ <enum value="48" name="VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO" comment="Reserved for internal use by the loader, layers, and ICDs"/>
+ </enums>
+ <enums name="VkSubpassContents" type="enum">
+ <enum value="0" name="VK_SUBPASS_CONTENTS_INLINE"/>
+ <enum value="1" name="VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS"/>
+ </enums>
+ <enums name="VkResult" type="enum" comment="API result codes">
+ <comment>Return codes (positive values)</comment>
+ <enum value="0" name="VK_SUCCESS" comment="Command completed successfully"/>
+ <enum value="1" name="VK_NOT_READY" comment="A fence or query has not yet completed"/>
+ <enum value="2" name="VK_TIMEOUT" comment="A wait operation has not completed in the specified time"/>
+ <enum value="3" name="VK_EVENT_SET" comment="An event is signaled"/>
+ <enum value="4" name="VK_EVENT_RESET" comment="An event is unsignaled"/>
+ <enum value="5" name="VK_INCOMPLETE" comment="A return array was too small for the result"/>
+ <comment>Error codes (negative values)</comment>
+ <enum value="-1" name="VK_ERROR_OUT_OF_HOST_MEMORY" comment="A host memory allocation has failed"/>
+ <enum value="-2" name="VK_ERROR_OUT_OF_DEVICE_MEMORY" comment="A device memory allocation has failed"/>
+ <enum value="-3" name="VK_ERROR_INITIALIZATION_FAILED" comment="Initialization of a object has failed"/>
+ <enum value="-4" name="VK_ERROR_DEVICE_LOST" comment="The logical device has been lost. See <<devsandqueues-lost-device>>"/>
+ <enum value="-5" name="VK_ERROR_MEMORY_MAP_FAILED" comment="Mapping of a memory object has failed"/>
+ <enum value="-6" name="VK_ERROR_LAYER_NOT_PRESENT" comment="Layer specified does not exist"/>
+ <enum value="-7" name="VK_ERROR_EXTENSION_NOT_PRESENT" comment="Extension specified does not exist"/>
+ <enum value="-8" name="VK_ERROR_FEATURE_NOT_PRESENT" comment="Requested feature is not available on this device"/>
+ <enum value="-9" name="VK_ERROR_INCOMPATIBLE_DRIVER" comment="Unable to find a Vulkan driver"/>
+ <enum value="-10" name="VK_ERROR_TOO_MANY_OBJECTS" comment="Too many objects of the type have already been created"/>
+ <enum value="-11" name="VK_ERROR_FORMAT_NOT_SUPPORTED" comment="Requested format is not supported on this device"/>
+ <enum value="-12" name="VK_ERROR_FRAGMENTED_POOL" comment="A requested pool allocation has failed due to fragmentation of the pool's memory"/>
+ <unused start="-12"/>
+ </enums>
+ <enums name="VkDynamicState" type="enum">
+ <enum value="0" name="VK_DYNAMIC_STATE_VIEWPORT"/>
+ <enum value="1" name="VK_DYNAMIC_STATE_SCISSOR"/>
+ <enum value="2" name="VK_DYNAMIC_STATE_LINE_WIDTH"/>
+ <enum value="3" name="VK_DYNAMIC_STATE_DEPTH_BIAS"/>
+ <enum value="4" name="VK_DYNAMIC_STATE_BLEND_CONSTANTS"/>
+ <enum value="5" name="VK_DYNAMIC_STATE_DEPTH_BOUNDS"/>
+ <enum value="6" name="VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK"/>
+ <enum value="7" name="VK_DYNAMIC_STATE_STENCIL_WRITE_MASK"/>
+ <enum value="8" name="VK_DYNAMIC_STATE_STENCIL_REFERENCE"/>
+ </enums>
+ <enums name="VkDescriptorUpdateTemplateType" type="enum">
+ <enum value="0" name="VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET" comment="Create descriptor update template for descriptor set updates"/>
+ </enums>
+ <enums name="VkObjectType" type="enum" comment="Enums to track objects of various types">
+ <enum value="0" name="VK_OBJECT_TYPE_UNKNOWN"/>
+ <enum value="1" name="VK_OBJECT_TYPE_INSTANCE" comment="VkInstance"/>
+ <enum value="2" name="VK_OBJECT_TYPE_PHYSICAL_DEVICE" comment="VkPhysicalDevice"/>
+ <enum value="3" name="VK_OBJECT_TYPE_DEVICE" comment="VkDevice"/>
+ <enum value="4" name="VK_OBJECT_TYPE_QUEUE" comment="VkQueue"/>
+ <enum value="5" name="VK_OBJECT_TYPE_SEMAPHORE" comment="VkSemaphore"/>
+ <enum value="6" name="VK_OBJECT_TYPE_COMMAND_BUFFER" comment="VkCommandBuffer"/>
+ <enum value="7" name="VK_OBJECT_TYPE_FENCE" comment="VkFence"/>
+ <enum value="8" name="VK_OBJECT_TYPE_DEVICE_MEMORY" comment="VkDeviceMemory"/>
+ <enum value="9" name="VK_OBJECT_TYPE_BUFFER" comment="VkBuffer"/>
+ <enum value="10" name="VK_OBJECT_TYPE_IMAGE" comment="VkImage"/>
+ <enum value="11" name="VK_OBJECT_TYPE_EVENT" comment="VkEvent"/>
+ <enum value="12" name="VK_OBJECT_TYPE_QUERY_POOL" comment="VkQueryPool"/>
+ <enum value="13" name="VK_OBJECT_TYPE_BUFFER_VIEW" comment="VkBufferView"/>
+ <enum value="14" name="VK_OBJECT_TYPE_IMAGE_VIEW" comment="VkImageView"/>
+ <enum value="15" name="VK_OBJECT_TYPE_SHADER_MODULE" comment="VkShaderModule"/>
+ <enum value="16" name="VK_OBJECT_TYPE_PIPELINE_CACHE" comment="VkPipelineCache"/>
+ <enum value="17" name="VK_OBJECT_TYPE_PIPELINE_LAYOUT" comment="VkPipelineLayout"/>
+ <enum value="18" name="VK_OBJECT_TYPE_RENDER_PASS" comment="VkRenderPass"/>
+ <enum value="19" name="VK_OBJECT_TYPE_PIPELINE" comment="VkPipeline"/>
+ <enum value="20" name="VK_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT" comment="VkDescriptorSetLayout"/>
+ <enum value="21" name="VK_OBJECT_TYPE_SAMPLER" comment="VkSampler"/>
+ <enum value="22" name="VK_OBJECT_TYPE_DESCRIPTOR_POOL" comment="VkDescriptorPool"/>
+ <enum value="23" name="VK_OBJECT_TYPE_DESCRIPTOR_SET" comment="VkDescriptorSet"/>
+ <enum value="24" name="VK_OBJECT_TYPE_FRAMEBUFFER" comment="VkFramebuffer"/>
+ <enum value="25" name="VK_OBJECT_TYPE_COMMAND_POOL" comment="VkCommandPool"/>
+ </enums>
+
+ <comment>Flags</comment>
+ <enums name="VkQueueFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_QUEUE_GRAPHICS_BIT" comment="Queue supports graphics operations"/>
+ <enum bitpos="1" name="VK_QUEUE_COMPUTE_BIT" comment="Queue supports compute operations"/>
+ <enum bitpos="2" name="VK_QUEUE_TRANSFER_BIT" comment="Queue supports transfer operations"/>
+ <enum bitpos="3" name="VK_QUEUE_SPARSE_BINDING_BIT" comment="Queue supports sparse resource memory management operations"/>
+ </enums>
+ <enums name="VkDeviceQueueCreateFlagBits" type="bitmask"></enums>
+ <enums name="VkMemoryPropertyFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT" comment="If otherwise stated, then allocate memory on device"/>
+ <enum bitpos="1" name="VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT" comment="Memory is mappable by host"/>
+ <enum bitpos="2" name="VK_MEMORY_PROPERTY_HOST_COHERENT_BIT" comment="Memory will have i/o coherency. If not set, application may need to use vkFlushMappedMemoryRanges and vkInvalidateMappedMemoryRanges to flush/invalidate host cache"/>
+ <enum bitpos="3" name="VK_MEMORY_PROPERTY_HOST_CACHED_BIT" comment="Memory will be cached by the host"/>
+ <enum bitpos="4" name="VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT" comment="Memory may be allocated by the driver when it is required"/>
+ </enums>
+ <enums name="VkMemoryHeapFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_MEMORY_HEAP_DEVICE_LOCAL_BIT" comment="If set, heap represents device memory"/>
+ </enums>
+ <enums name="VkAccessFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_ACCESS_INDIRECT_COMMAND_READ_BIT" comment="Controls coherency of indirect command reads"/>
+ <enum bitpos="1" name="VK_ACCESS_INDEX_READ_BIT" comment="Controls coherency of index reads"/>
+ <enum bitpos="2" name="VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT" comment="Controls coherency of vertex attribute reads"/>
+ <enum bitpos="3" name="VK_ACCESS_UNIFORM_READ_BIT" comment="Controls coherency of uniform buffer reads"/>
+ <enum bitpos="4" name="VK_ACCESS_INPUT_ATTACHMENT_READ_BIT" comment="Controls coherency of input attachment reads"/>
+ <enum bitpos="5" name="VK_ACCESS_SHADER_READ_BIT" comment="Controls coherency of shader reads"/>
+ <enum bitpos="6" name="VK_ACCESS_SHADER_WRITE_BIT" comment="Controls coherency of shader writes"/>
+ <enum bitpos="7" name="VK_ACCESS_COLOR_ATTACHMENT_READ_BIT" comment="Controls coherency of color attachment reads"/>
+ <enum bitpos="8" name="VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT" comment="Controls coherency of color attachment writes"/>
+ <enum bitpos="9" name="VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT" comment="Controls coherency of depth/stencil attachment reads"/>
+ <enum bitpos="10" name="VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT" comment="Controls coherency of depth/stencil attachment writes"/>
+ <enum bitpos="11" name="VK_ACCESS_TRANSFER_READ_BIT" comment="Controls coherency of transfer reads"/>
+ <enum bitpos="12" name="VK_ACCESS_TRANSFER_WRITE_BIT" comment="Controls coherency of transfer writes"/>
+ <enum bitpos="13" name="VK_ACCESS_HOST_READ_BIT" comment="Controls coherency of host reads"/>
+ <enum bitpos="14" name="VK_ACCESS_HOST_WRITE_BIT" comment="Controls coherency of host writes"/>
+ <enum bitpos="15" name="VK_ACCESS_MEMORY_READ_BIT" comment="Controls coherency of memory reads"/>
+ <enum bitpos="16" name="VK_ACCESS_MEMORY_WRITE_BIT" comment="Controls coherency of memory writes"/>
+ </enums>
+ <enums name="VkBufferUsageFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_BUFFER_USAGE_TRANSFER_SRC_BIT" comment="Can be used as a source of transfer operations"/>
+ <enum bitpos="1" name="VK_BUFFER_USAGE_TRANSFER_DST_BIT" comment="Can be used as a destination of transfer operations"/>
+ <enum bitpos="2" name="VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT" comment="Can be used as TBO"/>
+ <enum bitpos="3" name="VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT" comment="Can be used as IBO"/>
+ <enum bitpos="4" name="VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT" comment="Can be used as UBO"/>
+ <enum bitpos="5" name="VK_BUFFER_USAGE_STORAGE_BUFFER_BIT" comment="Can be used as SSBO"/>
+ <enum bitpos="6" name="VK_BUFFER_USAGE_INDEX_BUFFER_BIT" comment="Can be used as source of fixed-function index fetch (index buffer)"/>
+ <enum bitpos="7" name="VK_BUFFER_USAGE_VERTEX_BUFFER_BIT" comment="Can be used as source of fixed-function vertex fetch (VBO)"/>
+ <enum bitpos="8" name="VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT" comment="Can be the source of indirect parameters (e.g. indirect buffer, parameter buffer)"/>
+ </enums>
+ <enums name="VkBufferCreateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_BUFFER_CREATE_SPARSE_BINDING_BIT" comment="Buffer should support sparse backing"/>
+ <enum bitpos="1" name="VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT" comment="Buffer should support sparse backing with partial residency"/>
+ <enum bitpos="2" name="VK_BUFFER_CREATE_SPARSE_ALIASED_BIT" comment="Buffer should support constent data access to physical memory ranges mapped into multiple locations of sparse buffers"/>
+ </enums>
+ <enums name="VkShaderStageFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_SHADER_STAGE_VERTEX_BIT"/>
+ <enum bitpos="1" name="VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT"/>
+ <enum bitpos="2" name="VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT"/>
+ <enum bitpos="3" name="VK_SHADER_STAGE_GEOMETRY_BIT"/>
+ <enum bitpos="4" name="VK_SHADER_STAGE_FRAGMENT_BIT"/>
+ <enum bitpos="5" name="VK_SHADER_STAGE_COMPUTE_BIT"/>
+ <enum value="0x0000001F" name="VK_SHADER_STAGE_ALL_GRAPHICS"/>
+ <enum value="0x7FFFFFFF" name="VK_SHADER_STAGE_ALL"/>
+ </enums>
+ <enums name="VkImageUsageFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_IMAGE_USAGE_TRANSFER_SRC_BIT" comment="Can be used as a source of transfer operations"/>
+ <enum bitpos="1" name="VK_IMAGE_USAGE_TRANSFER_DST_BIT" comment="Can be used as a destination of transfer operations"/>
+ <enum bitpos="2" name="VK_IMAGE_USAGE_SAMPLED_BIT" comment="Can be sampled from (SAMPLED_IMAGE and COMBINED_IMAGE_SAMPLER descriptor types)"/>
+ <enum bitpos="3" name="VK_IMAGE_USAGE_STORAGE_BIT" comment="Can be used as storage image (STORAGE_IMAGE descriptor type)"/>
+ <enum bitpos="4" name="VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT" comment="Can be used as framebuffer color attachment"/>
+ <enum bitpos="5" name="VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT" comment="Can be used as framebuffer depth/stencil attachment"/>
+ <enum bitpos="6" name="VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT" comment="Image data not needed outside of rendering"/>
+ <enum bitpos="7" name="VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT" comment="Can be used as framebuffer input attachment"/>
+ </enums>
+ <enums name="VkImageCreateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_IMAGE_CREATE_SPARSE_BINDING_BIT" comment="Image should support sparse backing"/>
+ <enum bitpos="1" name="VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT" comment="Image should support sparse backing with partial residency"/>
+ <enum bitpos="2" name="VK_IMAGE_CREATE_SPARSE_ALIASED_BIT" comment="Image should support constent data access to physical memory ranges mapped into multiple locations of sparse images"/>
+ <enum bitpos="3" name="VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT" comment="Allows image views to have different format than the base image"/>
+ <enum bitpos="4" name="VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT" comment="Allows creating image views with cube type from the created image"/>
+ </enums>
+ <enums name="VkPipelineCreateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT"/>
+ <enum bitpos="1" name="VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT"/>
+ <enum bitpos="2" name="VK_PIPELINE_CREATE_DERIVATIVE_BIT"/>
+ </enums>
+ <enums name="VkColorComponentFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_COLOR_COMPONENT_R_BIT"/>
+ <enum bitpos="1" name="VK_COLOR_COMPONENT_G_BIT"/>
+ <enum bitpos="2" name="VK_COLOR_COMPONENT_B_BIT"/>
+ <enum bitpos="3" name="VK_COLOR_COMPONENT_A_BIT"/>
+ </enums>
+ <enums name="VkFenceCreateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_FENCE_CREATE_SIGNALED_BIT"/>
+ </enums>
+ <enums name="VkFormatFeatureFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT" comment="Format can be used for sampled images (SAMPLED_IMAGE and COMBINED_IMAGE_SAMPLER descriptor types)"/>
+ <enum bitpos="1" name="VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT" comment="Format can be used for storage images (STORAGE_IMAGE descriptor type)"/>
+ <enum bitpos="2" name="VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT" comment="Format supports atomic operations in case it is used for storage images"/>
+ <enum bitpos="3" name="VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT" comment="Format can be used for uniform texel buffers (TBOs)"/>
+ <enum bitpos="4" name="VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT" comment="Format can be used for storage texel buffers (IBOs)"/>
+ <enum bitpos="5" name="VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT" comment="Format supports atomic operations in case it is used for storage texel buffers"/>
+ <enum bitpos="6" name="VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT" comment="Format can be used for vertex buffers (VBOs)"/>
+ <enum bitpos="7" name="VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT" comment="Format can be used for color attachment images"/>
+ <enum bitpos="8" name="VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT" comment="Format supports blending in case it is used for color attachment images"/>
+ <enum bitpos="9" name="VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT" comment="Format can be used for depth/stencil attachment images"/>
+ <enum bitpos="10" name="VK_FORMAT_FEATURE_BLIT_SRC_BIT" comment="Format can be used as the source image of blits with vkCmdBlitImage"/>
+ <enum bitpos="11" name="VK_FORMAT_FEATURE_BLIT_DST_BIT" comment="Format can be used as the destination image of blits with vkCmdBlitImage"/>
+ <enum bitpos="12" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT" comment="Format can be filtered with VK_FILTER_LINEAR when being sampled"/>
+ </enums>
+ <enums name="VkQueryControlFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_QUERY_CONTROL_PRECISE_BIT" comment="Require precise results to be collected by the query"/>
+ </enums>
+ <enums name="VkQueryResultFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_QUERY_RESULT_64_BIT" comment="Results of the queries are written to the destination buffer as 64-bit values"/>
+ <enum bitpos="1" name="VK_QUERY_RESULT_WAIT_BIT" comment="Results of the queries are waited on before proceeding with the result copy"/>
+ <enum bitpos="2" name="VK_QUERY_RESULT_WITH_AVAILABILITY_BIT" comment="Besides the results of the query, the availability of the results is also written"/>
+ <enum bitpos="3" name="VK_QUERY_RESULT_PARTIAL_BIT" comment="Copy the partial results of the query even if the final results are not available"/>
+ </enums>
+ <enums name="VkCommandBufferUsageFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT"/>
+ <enum bitpos="1" name="VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT"/>
+ <enum bitpos="2" name="VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT" comment="Command buffer may be submitted/executed more than once simultaneously"/>
+ </enums>
+ <enums name="VkQueryPipelineStatisticFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT" comment="Optional"/>
+ <enum bitpos="1" name="VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT" comment="Optional"/>
+ <enum bitpos="2" name="VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT" comment="Optional"/>
+ <enum bitpos="3" name="VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT" comment="Optional"/>
+ <enum bitpos="4" name="VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT" comment="Optional"/>
+ <enum bitpos="5" name="VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT" comment="Optional"/>
+ <enum bitpos="6" name="VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT" comment="Optional"/>
+ <enum bitpos="7" name="VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT" comment="Optional"/>
+ <enum bitpos="8" name="VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT" comment="Optional"/>
+ <enum bitpos="9" name="VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT" comment="Optional"/>
+ <enum bitpos="10" name="VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT" comment="Optional"/>
+ </enums>
+ <enums name="VkImageAspectFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_IMAGE_ASPECT_COLOR_BIT"/>
+ <enum bitpos="1" name="VK_IMAGE_ASPECT_DEPTH_BIT"/>
+ <enum bitpos="2" name="VK_IMAGE_ASPECT_STENCIL_BIT"/>
+ <enum bitpos="3" name="VK_IMAGE_ASPECT_METADATA_BIT"/>
+ </enums>
+ <enums name="VkSparseImageFormatFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT" comment="Image uses a single mip tail region for all array layers"/>
+ <enum bitpos="1" name="VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT" comment="Image requires mip level dimensions to be an integer multiple of the sparse image block dimensions for non-tail mip levels."/>
+ <enum bitpos="2" name="VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT" comment="Image uses a non-standard sparse image block dimensions"/>
+ </enums>
+ <enums name="VkSparseMemoryBindFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_SPARSE_MEMORY_BIND_METADATA_BIT" comment="Operation binds resource metadata to memory"/>
+ </enums>
+ <enums name="VkPipelineStageFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT" comment="Before subsequent commands are processed"/>
+ <enum bitpos="1" name="VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT" comment="Draw/DispatchIndirect command fetch"/>
+ <enum bitpos="2" name="VK_PIPELINE_STAGE_VERTEX_INPUT_BIT" comment="Vertex/index fetch"/>
+ <enum bitpos="3" name="VK_PIPELINE_STAGE_VERTEX_SHADER_BIT" comment="Vertex shading"/>
+ <enum bitpos="4" name="VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT" comment="Tessellation control shading"/>
+ <enum bitpos="5" name="VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT" comment="Tessellation evaluation shading"/>
+ <enum bitpos="6" name="VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT" comment="Geometry shading"/>
+ <enum bitpos="7" name="VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT" comment="Fragment shading"/>
+ <enum bitpos="8" name="VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT" comment="Early fragment (depth and stencil) tests"/>
+ <enum bitpos="9" name="VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT" comment="Late fragment (depth and stencil) tests"/>
+ <enum bitpos="10" name="VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT" comment="Color attachment writes"/>
+ <enum bitpos="11" name="VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT" comment="Compute shading"/>
+ <enum bitpos="12" name="VK_PIPELINE_STAGE_TRANSFER_BIT" comment="Transfer/copy operations"/>
+ <enum bitpos="13" name="VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT" comment="After previous commands have completed"/>
+ <enum bitpos="14" name="VK_PIPELINE_STAGE_HOST_BIT" comment="Indicates host (CPU) is a source/sink of the dependency"/>
+ <enum bitpos="15" name="VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT" comment="All stages of the graphics pipeline"/>
+ <enum bitpos="16" name="VK_PIPELINE_STAGE_ALL_COMMANDS_BIT" comment="All stages supported on the queue"/>
+ </enums>
+ <enums name="VkCommandPoolCreateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_COMMAND_POOL_CREATE_TRANSIENT_BIT" comment="Command buffers have a short lifetime"/>
+ <enum bitpos="1" name="VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT" comment="Command buffers may release their memory individually"/>
+ </enums>
+ <enums name="VkCommandPoolResetFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_COMMAND_POOL_RESET_RELEASE_RESOURCES_BIT" comment="Release resources owned by the pool"/>
+ </enums>
+ <enums name="VkCommandBufferResetFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT" comment="Release resources owned by the buffer"/>
+ </enums>
+ <enums name="VkSampleCountFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_SAMPLE_COUNT_1_BIT" comment="Sample count 1 supported"/>
+ <enum bitpos="1" name="VK_SAMPLE_COUNT_2_BIT" comment="Sample count 2 supported"/>
+ <enum bitpos="2" name="VK_SAMPLE_COUNT_4_BIT" comment="Sample count 4 supported"/>
+ <enum bitpos="3" name="VK_SAMPLE_COUNT_8_BIT" comment="Sample count 8 supported"/>
+ <enum bitpos="4" name="VK_SAMPLE_COUNT_16_BIT" comment="Sample count 16 supported"/>
+ <enum bitpos="5" name="VK_SAMPLE_COUNT_32_BIT" comment="Sample count 32 supported"/>
+ <enum bitpos="6" name="VK_SAMPLE_COUNT_64_BIT" comment="Sample count 64 supported"/>
+ </enums>
+ <enums name="VkAttachmentDescriptionFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT" comment="The attachment may alias physical memory of another attachment in the same render pass"/>
+ </enums>
+ <enums name="VkStencilFaceFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_STENCIL_FACE_FRONT_BIT" comment="Front face"/>
+ <enum bitpos="1" name="VK_STENCIL_FACE_BACK_BIT" comment="Back face"/>
+ <enum value="0x00000003" name="VK_STENCIL_FRONT_AND_BACK" comment="Front and back faces"/>
+ </enums>
+ <enums name="VkDescriptorPoolCreateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT" comment="Descriptor sets may be freed individually"/>
+ </enums>
+ <enums name="VkDependencyFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_DEPENDENCY_BY_REGION_BIT" comment="Dependency is per pixel region "/>
+ </enums>
+
+ <comment>WSI Extensions</comment>
+ <enums name="VkPresentModeKHR" type="enum">
+ <enum value="0" name="VK_PRESENT_MODE_IMMEDIATE_KHR"/>
+ <enum value="1" name="VK_PRESENT_MODE_MAILBOX_KHR"/>
+ <enum value="2" name="VK_PRESENT_MODE_FIFO_KHR"/>
+ <enum value="3" name="VK_PRESENT_MODE_FIFO_RELAXED_KHR"/>
+ </enums>
+ <enums name="VkColorSpaceKHR" type="enum">
+ <enum value="0" name="VK_COLOR_SPACE_SRGB_NONLINEAR_KHR"/>
+ </enums>
+ <enums name="VkDisplayPlaneAlphaFlagBitsKHR" type="bitmask">
+ <enum bitpos="0" name="VK_DISPLAY_PLANE_ALPHA_OPAQUE_BIT_KHR"/>
+ <enum bitpos="1" name="VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR"/>
+ <enum bitpos="2" name="VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR"/>
+ <enum bitpos="3" name="VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_PREMULTIPLIED_BIT_KHR"/>
+ </enums>
+ <enums name="VkCompositeAlphaFlagBitsKHR" type="bitmask">
+ <enum bitpos="0" name="VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR"/>
+ <enum bitpos="1" name="VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR"/>
+ <enum bitpos="2" name="VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR"/>
+ <enum bitpos="3" name="VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR"/>
+ </enums>
+ <enums name="VkSurfaceTransformFlagBitsKHR" type="bitmask">
+ <enum bitpos="0" name="VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR"/>
+ <enum bitpos="1" name="VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR"/>
+ <enum bitpos="2" name="VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR"/>
+ <enum bitpos="3" name="VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR"/>
+ <enum bitpos="4" name="VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR"/>
+ <enum bitpos="5" name="VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR"/>
+ <enum bitpos="6" name="VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR"/>
+ <enum bitpos="7" name="VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR"/>
+ <enum bitpos="8" name="VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR"/>
+ </enums>
+ <enums name="VkDebugReportFlagBitsEXT" type="bitmask">
+ <enum bitpos="0" name="VK_DEBUG_REPORT_INFORMATION_BIT_EXT"/>
+ <enum bitpos="1" name="VK_DEBUG_REPORT_WARNING_BIT_EXT"/>
+ <enum bitpos="2" name="VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT"/>
+ <enum bitpos="3" name="VK_DEBUG_REPORT_ERROR_BIT_EXT"/>
+ <enum bitpos="4" name="VK_DEBUG_REPORT_DEBUG_BIT_EXT"/>
+ </enums>
+ <enums name="VkDebugReportObjectTypeEXT" type="enum">
+ <enum value="0" name="VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT"/>
+ <enum value="1" name="VK_DEBUG_REPORT_OBJECT_TYPE_INSTANCE_EXT"/>
+ <enum value="2" name="VK_DEBUG_REPORT_OBJECT_TYPE_PHYSICAL_DEVICE_EXT"/>
+ <enum value="3" name="VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_EXT"/>
+ <enum value="4" name="VK_DEBUG_REPORT_OBJECT_TYPE_QUEUE_EXT"/>
+ <enum value="5" name="VK_DEBUG_REPORT_OBJECT_TYPE_SEMAPHORE_EXT"/>
+ <enum value="6" name="VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_BUFFER_EXT"/>
+ <enum value="7" name="VK_DEBUG_REPORT_OBJECT_TYPE_FENCE_EXT"/>
+ <enum value="8" name="VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMORY_EXT"/>
+ <enum value="9" name="VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT"/>
+ <enum value="10" name="VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT"/>
+ <enum value="11" name="VK_DEBUG_REPORT_OBJECT_TYPE_EVENT_EXT"/>
+ <enum value="12" name="VK_DEBUG_REPORT_OBJECT_TYPE_QUERY_POOL_EXT"/>
+ <enum value="13" name="VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_VIEW_EXT"/>
+ <enum value="14" name="VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_VIEW_EXT"/>
+ <enum value="15" name="VK_DEBUG_REPORT_OBJECT_TYPE_SHADER_MODULE_EXT"/>
+ <enum value="16" name="VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_CACHE_EXT"/>
+ <enum value="17" name="VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_LAYOUT_EXT"/>
+ <enum value="18" name="VK_DEBUG_REPORT_OBJECT_TYPE_RENDER_PASS_EXT"/>
+ <enum value="19" name="VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EXT"/>
+ <enum value="20" name="VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT_EXT"/>
+ <enum value="21" name="VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_EXT"/>
+ <enum value="22" name="VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_POOL_EXT"/>
+ <enum value="23" name="VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_SET_EXT"/>
+ <enum value="24" name="VK_DEBUG_REPORT_OBJECT_TYPE_FRAMEBUFFER_EXT"/>
+ <enum value="25" name="VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_POOL_EXT"/>
+ <enum value="26" name="VK_DEBUG_REPORT_OBJECT_TYPE_SURFACE_KHR_EXT"/>
+ <enum value="27" name="VK_DEBUG_REPORT_OBJECT_TYPE_SWAPCHAIN_KHR_EXT"/>
+ <enum value="28" name="VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT"/>
+ <enum value="29" name="VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_KHR_EXT"/>
+ <enum value="30" name="VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_MODE_KHR_EXT"/>
+ <enum value="31" name="VK_DEBUG_REPORT_OBJECT_TYPE_OBJECT_TABLE_NVX_EXT"/>
+ <enum value="32" name="VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX_EXT"/>
+ <enum value="33" name="VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT"/>
+ </enums>
+ <enums name="VkRasterizationOrderAMD" type="enum">
+ <enum value="0" name="VK_RASTERIZATION_ORDER_STRICT_AMD"/>
+ <enum value="1" name="VK_RASTERIZATION_ORDER_RELAXED_AMD"/>
+ </enums>
+ <enums name="VkExternalMemoryHandleTypeFlagBitsNV" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_NV"/>
+ <enum bitpos="1" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_NV"/>
+ <enum bitpos="2" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_BIT_NV"/>
+ <enum bitpos="3" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_KMT_BIT_NV"/>
+ </enums>
+ <enums name="VkExternalMemoryFeatureFlagBitsNV" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_NV"/>
+ <enum bitpos="1" name="VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_NV"/>
+ <enum bitpos="2" name="VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_NV"/>
+ </enums>
+ <enums name="VkValidationCheckEXT" type="enum">
+ <enum value="0" name="VK_VALIDATION_CHECK_ALL_EXT"/>
+ <enum value="1" name="VK_VALIDATION_CHECK_SHADERS_EXT"/>
+ <comment>Placeholder for validation enums to be defined for VK_EXT_Validation_flags extension</comment>
+ </enums>
+ <enums name="VkSubgroupFeatureFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_SUBGROUP_FEATURE_BASIC_BIT" comment="Basic subgroup operations"/>
+ <enum bitpos="1" name="VK_SUBGROUP_FEATURE_VOTE_BIT" comment="Vote subgroup operations"/>
+ <enum bitpos="2" name="VK_SUBGROUP_FEATURE_ARITHMETIC_BIT" comment="Arithmetic subgroup operations"/>
+ <enum bitpos="3" name="VK_SUBGROUP_FEATURE_BALLOT_BIT" comment="Ballot subgroup operations"/>
+ <enum bitpos="4" name="VK_SUBGROUP_FEATURE_SHUFFLE_BIT" comment="Shuffle subgroup operations"/>
+ <enum bitpos="5" name="VK_SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT" comment="Shuffle relative subgroup operations"/>
+ <enum bitpos="6" name="VK_SUBGROUP_FEATURE_CLUSTERED_BIT" comment="Clustered subgroup operations"/>
+ <enum bitpos="7" name="VK_SUBGROUP_FEATURE_QUAD_BIT" comment="Quad subgroup operations"/>
+ </enums>
+ <enums name="VkIndirectCommandsLayoutUsageFlagBitsNVX" type="bitmask">
+ <enum bitpos="0" name="VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX"/>
+ <enum bitpos="1" name="VK_INDIRECT_COMMANDS_LAYOUT_USAGE_SPARSE_SEQUENCES_BIT_NVX"/>
+ <enum bitpos="2" name="VK_INDIRECT_COMMANDS_LAYOUT_USAGE_EMPTY_EXECUTIONS_BIT_NVX"/>
+ <enum bitpos="3" name="VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX"/>
+ </enums>
+ <enums name="VkObjectEntryUsageFlagBitsNVX" type="bitmask">
+ <enum bitpos="0" name="VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX"/>
+ <enum bitpos="1" name="VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX"/>
+ </enums>
+ <enums name="VkIndirectCommandsTokenTypeNVX" type="enum">
+ <enum value="0" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX"/>
+ <enum value="1" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_DESCRIPTOR_SET_NVX"/>
+ <enum value="2" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_INDEX_BUFFER_NVX"/>
+ <enum value="3" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_VERTEX_BUFFER_NVX"/>
+ <enum value="4" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_PUSH_CONSTANT_NVX"/>
+ <enum value="5" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED_NVX"/>
+ <enum value="6" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX"/>
+ <enum value="7" name="VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX"/>
+ </enums>
+ <enums name="VkObjectEntryTypeNVX" type="enum">
+ <enum value="0" name="VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX"/>
+ <enum value="1" name="VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX"/>
+ <enum value="2" name="VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX"/>
+ <enum value="3" name="VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX"/>
+ <enum value="4" name="VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX"/>
+ </enums>
+ <enums name="VkDescriptorSetLayoutCreateFlagBits" type="bitmask">
+ </enums>
+ <enums name="VkExternalMemoryHandleTypeFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT"/>
+ <enum bitpos="1" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT"/>
+ <enum bitpos="2" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT"/>
+ <enum bitpos="3" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT"/>
+ <enum bitpos="4" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT"/>
+ <enum bitpos="5" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT"/>
+ <enum bitpos="6" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT"/>
+ </enums>
+ <enums name="VkExternalMemoryFeatureFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT"/>
+ <enum bitpos="1" name="VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT"/>
+ <enum bitpos="2" name="VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT"/>
+ </enums>
+ <enums name="VkExternalSemaphoreHandleTypeFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT"/>
+ <enum bitpos="1" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT"/>
+ <enum bitpos="2" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT"/>
+ <enum bitpos="3" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT"/>
+ <enum bitpos="4" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT"/>
+ </enums>
+ <enums name="VkExternalSemaphoreFeatureFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT"/>
+ <enum bitpos="1" name="VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT"/>
+ </enums>
+ <enums name="VkSemaphoreImportFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_SEMAPHORE_IMPORT_TEMPORARY_BIT"/>
+ </enums>
+ <enums name="VkExternalFenceHandleTypeFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT"/>
+ <enum bitpos="1" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT"/>
+ <enum bitpos="2" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT"/>
+ <enum bitpos="3" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT"/>
+ </enums>
+ <enums name="VkExternalFenceFeatureFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT"/>
+ <enum bitpos="1" name="VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT"/>
+ </enums>
+ <enums name="VkFenceImportFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_FENCE_IMPORT_TEMPORARY_BIT"/>
+ </enums>
+ <enums name="VkSurfaceCounterFlagBitsEXT" type="bitmask">
+ <enum bitpos="0" name="VK_SURFACE_COUNTER_VBLANK_EXT"/>
+ </enums>
+ <enums name="VkDisplayPowerStateEXT" type="enum">
+ <enum value="0" name="VK_DISPLAY_POWER_STATE_OFF_EXT"/>
+ <enum value="1" name="VK_DISPLAY_POWER_STATE_SUSPEND_EXT"/>
+ <enum value="2" name="VK_DISPLAY_POWER_STATE_ON_EXT"/>
+ </enums>
+ <enums name="VkDeviceEventTypeEXT" type="enum">
+ <enum value="0" name="VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT"/>
+ </enums>
+ <enums name="VkDisplayEventTypeEXT" type="enum">
+ <enum value="0" name="VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT"/>
+ </enums>
+ <enums name="VkPeerMemoryFeatureFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT" comment="Can read with vkCmdCopy commands"/>
+ <enum bitpos="1" name="VK_PEER_MEMORY_FEATURE_COPY_DST_BIT" comment="Can write with vkCmdCopy commands"/>
+ <enum bitpos="2" name="VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT" comment="Can read with any access type/command"/>
+ <enum bitpos="3" name="VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT" comment="Can write with and access type/command"/>
+ </enums>
+ <enums name="VkMemoryAllocateFlagBits" type="bitmask">
+ <enum bitpos="0" name="VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT" comment="Force allocation on specific devices"/>
+ </enums>
+ <enums name="VkDeviceGroupPresentModeFlagBitsKHR" type="bitmask">
+ <enum bitpos="0" name="VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR" comment="Present from local memory"/>
+ <enum bitpos="1" name="VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR" comment="Present from remote memory"/>
+ <enum bitpos="2" name="VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR" comment="Present sum of local and/or remote memory"/>
+ <enum bitpos="3" name="VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR" comment="Each physical device presents from local memory"/>
+ </enums>
+ <enums name="VkSwapchainCreateFlagBitsKHR" type="bitmask">
+ </enums>
+ <enums name="VkViewportCoordinateSwizzleNV" type="enum">
+ <enum value="0" name="VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_X_NV"/>
+ <enum value="1" name="VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_X_NV"/>
+ <enum value="2" name="VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Y_NV"/>
+ <enum value="3" name="VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Y_NV"/>
+ <enum value="4" name="VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_Z_NV"/>
+ <enum value="5" name="VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_Z_NV"/>
+ <enum value="6" name="VK_VIEWPORT_COORDINATE_SWIZZLE_POSITIVE_W_NV"/>
+ <enum value="7" name="VK_VIEWPORT_COORDINATE_SWIZZLE_NEGATIVE_W_NV"/>
+ </enums>
+ <enums name="VkDiscardRectangleModeEXT" type="enum">
+ <enum value="0" name="VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT"/>
+ <enum value="1" name="VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT"/>
+ </enums>
+ <enums name="VkSubpassDescriptionFlagBits" type="bitmask">
+ </enums>
+ <enums name="VkPointClippingBehavior" type="enum">
+ <enum value="0" name="VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES"/>
+ <enum value="1" name="VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY"/>
+ </enums>
+ <enums name="VkSamplerReductionModeEXT" type="enum">
+ <enum value="0" name="VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT"/>
+ <enum value="1" name="VK_SAMPLER_REDUCTION_MODE_MIN_EXT"/>
+ <enum value="2" name="VK_SAMPLER_REDUCTION_MODE_MAX_EXT"/>
+ </enums>
+ <enums name="VkTessellationDomainOrigin" type="enum">
+ <enum value="0" name="VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT"/>
+ <enum value="1" name="VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT"/>
+ </enums>
+ <enums name="VkSamplerYcbcrModelConversion" type="enum">
+ <enum value="0" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY"/>
+ <enum value="1" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY" comment="just range expansion"/>
+ <enum value="2" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709" comment="aka HD YUV"/>
+ <enum value="3" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601" comment="aka SD YUV"/>
+ <enum value="4" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020" comment="aka UHD YUV"/>
+ </enums>
+ <enums name="VkSamplerYcbcrRange" type="enum">
+ <enum value="0" name="VK_SAMPLER_YCBCR_RANGE_ITU_FULL" comment="Luma 0..1 maps to 0..255, chroma -0.5..0.5 to 1..255 (clamped)"/>
+ <enum value="1" name="VK_SAMPLER_YCBCR_RANGE_ITU_NARROW" comment="Luma 0..1 maps to 16..235, chroma -0.5..0.5 to 16..240"/>
+ </enums>
+ <enums name="VkChromaLocation" type="enum">
+ <enum value="0" name="VK_CHROMA_LOCATION_COSITED_EVEN"/>
+ <enum value="1" name="VK_CHROMA_LOCATION_MIDPOINT"/>
+ </enums>
+ <enums name="VkBlendOverlapEXT" type="enum">
+ <enum value="0" name="VK_BLEND_OVERLAP_UNCORRELATED_EXT"/>
+ <enum value="1" name="VK_BLEND_OVERLAP_DISJOINT_EXT"/>
+ <enum value="2" name="VK_BLEND_OVERLAP_CONJOINT_EXT"/>
+ </enums>
+ <enums name="VkCoverageModulationModeNV" type="enum">
+ <enum value="0" name="VK_COVERAGE_MODULATION_MODE_NONE_NV"/>
+ <enum value="1" name="VK_COVERAGE_MODULATION_MODE_RGB_NV"/>
+ <enum value="2" name="VK_COVERAGE_MODULATION_MODE_ALPHA_NV"/>
+ <enum value="3" name="VK_COVERAGE_MODULATION_MODE_RGBA_NV"/>
+ </enums>
+ <enums name="VkValidationCacheHeaderVersionEXT" type="enum">
+ <enum value="1" name="VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT"/>
+ </enums>
+ <enums name="VkShaderInfoTypeAMD" type="enum">
+ <enum value="0" name="VK_SHADER_INFO_TYPE_STATISTICS_AMD"/>
+ <enum value="1" name="VK_SHADER_INFO_TYPE_BINARY_AMD"/>
+ <enum value="2" name="VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD"/>
+ </enums>
+ <enums name="VkQueueGlobalPriorityEXT" type="enum">
+ <enum value="128" name="VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT"/>
+ <enum value="256" name="VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT"/>
+ <enum value="512" name="VK_QUEUE_GLOBAL_PRIORITY_HIGH_EXT"/>
+ <enum value="1024" name="VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT"/>
+ </enums>
+ <enums name="VkDebugUtilsMessageSeverityFlagBitsEXT" type="bitmask">
+ <enum bitpos="0" name="VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT"/>
+ <enum bitpos="4" name="VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT"/>
+ <enum bitpos="8" name="VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT"/>
+ <enum bitpos="12" name="VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT"/>
+ </enums>
+ <enums name="VkDebugUtilsMessageTypeFlagBitsEXT" type="bitmask">
+ <enum bitpos="0" name="VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT"/>
+ <enum bitpos="1" name="VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT"/>
+ <enum bitpos="2" name="VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT"/>
+ </enums>
+ <enums name="VkConservativeRasterizationModeEXT" type="enum">
+ <enum value="0" name="VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT"/>
+ <enum value="1" name="VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT"/>
+ <enum value="2" name="VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT"/>
+ </enums>
+ <enums name="VkDescriptorBindingFlagBitsEXT" type="bitmask">
+ <enum bitpos="0" name="VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT"/>
+ <enum bitpos="1" name="VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT"/>
+ <enum bitpos="2" name="VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT"/>
+ <enum bitpos="3" name="VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT"/>
+ </enums>
+
+ <commands comment="Vulkan command definitions">
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INITIALIZATION_FAILED,VK_ERROR_LAYER_NOT_PRESENT,VK_ERROR_EXTENSION_NOT_PRESENT,VK_ERROR_INCOMPATIBLE_DRIVER">
+ <proto><type>VkResult</type> <name>vkCreateInstance</name></proto>
+ <param>const <type>VkInstanceCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkInstance</type>* <name>pInstance</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyInstance</name></proto>
+ <param optional="true" externsync="true"><type>VkInstance</type> <name>instance</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INITIALIZATION_FAILED">
+ <proto><type>VkResult</type> <name>vkEnumeratePhysicalDevices</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPhysicalDeviceCount</name></param>
+ <param optional="true" len="pPhysicalDeviceCount"><type>VkPhysicalDevice</type>* <name>pPhysicalDevices</name></param>
+ </command>
+ <command>
+ <proto><type>PFN_vkVoidFunction</type> <name>vkGetDeviceProcAddr</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param len="null-terminated">const <type>char</type>* <name>pName</name></param>
+ </command>
+ <command>
+ <proto><type>PFN_vkVoidFunction</type> <name>vkGetInstanceProcAddr</name></proto>
+ <param optional="true"><type>VkInstance</type> <name>instance</name></param>
+ <param len="null-terminated">const <type>char</type>* <name>pName</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkPhysicalDeviceProperties</type>* <name>pProperties</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceQueueFamilyProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pQueueFamilyPropertyCount</name></param>
+ <param optional="true" len="pQueueFamilyPropertyCount"><type>VkQueueFamilyProperties</type>* <name>pQueueFamilyProperties</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceMemoryProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkPhysicalDeviceMemoryProperties</type>* <name>pMemoryProperties</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceFeatures</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkPhysicalDeviceFeatures</type>* <name>pFeatures</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceFormatProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkFormat</type> <name>format</name></param>
+ <param><type>VkFormatProperties</type>* <name>pFormatProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_FORMAT_NOT_SUPPORTED">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceImageFormatProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkFormat</type> <name>format</name></param>
+ <param><type>VkImageType</type> <name>type</name></param>
+ <param><type>VkImageTiling</type> <name>tiling</name></param>
+ <param><type>VkImageUsageFlags</type> <name>usage</name></param>
+ <param optional="true"><type>VkImageCreateFlags</type> <name>flags</name></param>
+ <param><type>VkImageFormatProperties</type>* <name>pImageFormatProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INITIALIZATION_FAILED,VK_ERROR_EXTENSION_NOT_PRESENT,VK_ERROR_FEATURE_NOT_PRESENT,VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkCreateDevice</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkDeviceCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDevice</type>* <name>pDevice</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyDevice</name></proto>
+ <param optional="true" externsync="true"><type>VkDevice</type> <name>device</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS">
+ <proto><type>VkResult</type> <name>vkEnumerateInstanceVersion</name></proto>
+ <param><type>uint32_t</type>* <name>pApiVersion</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkEnumerateInstanceLayerProperties</name></proto>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkLayerProperties</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_LAYER_NOT_PRESENT">
+ <proto><type>VkResult</type> <name>vkEnumerateInstanceExtensionProperties</name></proto>
+ <param optional="true" len="null-terminated">const <type>char</type>* <name>pLayerName</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkExtensionProperties</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkEnumerateDeviceLayerProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkLayerProperties</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_LAYER_NOT_PRESENT">
+ <proto><type>VkResult</type> <name>vkEnumerateDeviceExtensionProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param optional="true" len="null-terminated">const <type>char</type>* <name>pLayerName</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkExtensionProperties</type>* <name>pProperties</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetDeviceQueue</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ <param><type>uint32_t</type> <name>queueIndex</name></param>
+ <param><type>VkQueue</type>* <name>pQueue</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkQueueSubmit</name></proto>
+ <param externsync="true"><type>VkQueue</type> <name>queue</name></param>
+ <param optional="true"><type>uint32_t</type> <name>submitCount</name></param>
+ <param len="submitCount" externsync="pSubmits[].pWaitSemaphores[],pSubmits[].pSignalSemaphores[]">const <type>VkSubmitInfo</type>* <name>pSubmits</name></param>
+ <param optional="true" externsync="true"><type>VkFence</type> <name>fence</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkQueueWaitIdle</name></proto>
+ <param><type>VkQueue</type> <name>queue</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkDeviceWaitIdle</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <implicitexternsyncparams>
+ <param>all sname:VkQueue objects created from pname:device</param>
+ </implicitexternsyncparams>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkAllocateMemory</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkMemoryAllocateInfo</type>* <name>pAllocateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDeviceMemory</type>* <name>pMemory</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkFreeMemory</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkDeviceMemory</type> <name>memory</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_MEMORY_MAP_FAILED">
+ <proto><type>VkResult</type> <name>vkMapMemory</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkDeviceMemory</type> <name>memory</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ <param><type>VkDeviceSize</type> <name>size</name></param>
+ <param optional="true"><type>VkMemoryMapFlags</type> <name>flags</name></param>
+ <param optional="false,true"><type>void</type>** <name>ppData</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkUnmapMemory</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkDeviceMemory</type> <name>memory</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkFlushMappedMemoryRanges</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>memoryRangeCount</name></param>
+ <param len="memoryRangeCount">const <type>VkMappedMemoryRange</type>* <name>pMemoryRanges</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkInvalidateMappedMemoryRanges</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>memoryRangeCount</name></param>
+ <param len="memoryRangeCount">const <type>VkMappedMemoryRange</type>* <name>pMemoryRanges</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetDeviceMemoryCommitment</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkDeviceMemory</type> <name>memory</name></param>
+ <param><type>VkDeviceSize</type>* <name>pCommittedMemoryInBytes</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetBufferMemoryRequirements</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkMemoryRequirements</type>* <name>pMemoryRequirements</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkBindBufferMemory</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceMemory</type> <name>memory</name></param>
+ <param><type>VkDeviceSize</type> <name>memoryOffset</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetImageMemoryRequirements</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param><type>VkMemoryRequirements</type>* <name>pMemoryRequirements</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkBindImageMemory</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkImage</type> <name>image</name></param>
+ <param><type>VkDeviceMemory</type> <name>memory</name></param>
+ <param><type>VkDeviceSize</type> <name>memoryOffset</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetImageSparseMemoryRequirements</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pSparseMemoryRequirementCount</name></param>
+ <param optional="true" len="pSparseMemoryRequirementCount"><type>VkSparseImageMemoryRequirements</type>* <name>pSparseMemoryRequirements</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceSparseImageFormatProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkFormat</type> <name>format</name></param>
+ <param><type>VkImageType</type> <name>type</name></param>
+ <param><type>VkSampleCountFlagBits</type> <name>samples</name></param>
+ <param><type>VkImageUsageFlags</type> <name>usage</name></param>
+ <param><type>VkImageTiling</type> <name>tiling</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkSparseImageFormatProperties</type>* <name>pProperties</name></param>
+ </command>
+ <command queues="sparse_binding" successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkQueueBindSparse</name></proto>
+ <param externsync="true"><type>VkQueue</type> <name>queue</name></param>
+ <param optional="true"><type>uint32_t</type> <name>bindInfoCount</name></param>
+ <param len="bindInfoCount" externsync="pBindInfo[].pWaitSemaphores[],pBindInfo[].pSignalSemaphores[],pBindInfo[].pBufferBinds[].buffer,pBindInfo[].pImageOpaqueBinds[].image,pBindInfo[].pImageBinds[].image">const <type>VkBindSparseInfo</type>* <name>pBindInfo</name></param>
+ <param optional="true" externsync="true"><type>VkFence</type> <name>fence</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateFence</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkFenceCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkFence</type>* <name>pFence</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyFence</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkFence</type> <name>fence</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkResetFences</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>fenceCount</name></param>
+ <param len="fenceCount" externsync="true">const <type>VkFence</type>* <name>pFences</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_NOT_READY" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkGetFenceStatus</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkFence</type> <name>fence</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_TIMEOUT" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkWaitForFences</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>fenceCount</name></param>
+ <param len="fenceCount">const <type>VkFence</type>* <name>pFences</name></param>
+ <param><type>VkBool32</type> <name>waitAll</name></param>
+ <param><type>uint64_t</type> <name>timeout</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateSemaphore</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkSemaphoreCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSemaphore</type>* <name>pSemaphore</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroySemaphore</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkSemaphore</type> <name>semaphore</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateEvent</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkEventCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkEvent</type>* <name>pEvent</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyEvent</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkEvent</type> <name>event</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_EVENT_SET,VK_EVENT_RESET" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkGetEventStatus</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkEvent</type> <name>event</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkSetEvent</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkEvent</type> <name>event</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkResetEvent</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkEvent</type> <name>event</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateQueryPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkQueryPoolCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkQueryPool</type>* <name>pQueryPool</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyQueryPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_NOT_READY" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST">
+ <proto><type>VkResult</type> <name>vkGetQueryPoolResults</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param><type>uint32_t</type> <name>firstQuery</name></param>
+ <param><type>uint32_t</type> <name>queryCount</name></param>
+ <param><type>size_t</type> <name>dataSize</name></param>
+ <param len="dataSize"><type>void</type>* <name>pData</name></param>
+ <param><type>VkDeviceSize</type> <name>stride</name></param>
+ <param optional="true"><type>VkQueryResultFlags</type> <name>flags</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateBuffer</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkBufferCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkBuffer</type>* <name>pBuffer</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyBuffer</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkBuffer</type> <name>buffer</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateBufferView</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkBufferViewCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkBufferView</type>* <name>pView</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyBufferView</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkBufferView</type> <name>bufferView</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateImage</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImageCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkImage</type>* <name>pImage</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyImage</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkImage</type> <name>image</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetImageSubresourceLayout</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param>const <type>VkImageSubresource</type>* <name>pSubresource</name></param>
+ <param><type>VkSubresourceLayout</type>* <name>pLayout</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateImageView</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImageViewCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkImageView</type>* <name>pView</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyImageView</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkImageView</type> <name>imageView</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INVALID_SHADER_NV">
+ <proto><type>VkResult</type> <name>vkCreateShaderModule</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkShaderModuleCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkShaderModule</type>* <name>pShaderModule</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyShaderModule</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkShaderModule</type> <name>shaderModule</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreatePipelineCache</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkPipelineCacheCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkPipelineCache</type>* <name>pPipelineCache</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyPipelineCache</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkPipelineCache</type> <name>pipelineCache</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetPipelineCacheData</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkPipelineCache</type> <name>pipelineCache</name></param>
+ <param optional="false,true"><type>size_t</type>* <name>pDataSize</name></param>
+ <param optional="true" len="pDataSize"><type>void</type>* <name>pData</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkMergePipelineCaches</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkPipelineCache</type> <name>dstCache</name></param>
+ <param><type>uint32_t</type> <name>srcCacheCount</name></param>
+ <param len="srcCacheCount">const <type>VkPipelineCache</type>* <name>pSrcCaches</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INVALID_SHADER_NV">
+ <proto><type>VkResult</type> <name>vkCreateGraphicsPipelines</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true"><type>VkPipelineCache</type> <name>pipelineCache</name></param>
+ <param><type>uint32_t</type> <name>createInfoCount</name></param>
+ <param len="createInfoCount">const <type>VkGraphicsPipelineCreateInfo</type>* <name>pCreateInfos</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param len="createInfoCount"><type>VkPipeline</type>* <name>pPipelines</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INVALID_SHADER_NV">
+ <proto><type>VkResult</type> <name>vkCreateComputePipelines</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true"><type>VkPipelineCache</type> <name>pipelineCache</name></param>
+ <param><type>uint32_t</type> <name>createInfoCount</name></param>
+ <param len="createInfoCount">const <type>VkComputePipelineCreateInfo</type>* <name>pCreateInfos</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param len="createInfoCount"><type>VkPipeline</type>* <name>pPipelines</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyPipeline</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkPipeline</type> <name>pipeline</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreatePipelineLayout</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkPipelineLayoutCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkPipelineLayout</type>* <name>pPipelineLayout</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyPipelineLayout</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkPipelineLayout</type> <name>pipelineLayout</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_TOO_MANY_OBJECTS">
+ <proto><type>VkResult</type> <name>vkCreateSampler</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkSamplerCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSampler</type>* <name>pSampler</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroySampler</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkSampler</type> <name>sampler</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateDescriptorSetLayout</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkDescriptorSetLayoutCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDescriptorSetLayout</type>* <name>pSetLayout</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyDescriptorSetLayout</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkDescriptorSetLayout</type> <name>descriptorSetLayout</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_FRAGMENTATION_EXT">
+ <proto><type>VkResult</type> <name>vkCreateDescriptorPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkDescriptorPoolCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDescriptorPool</type>* <name>pDescriptorPool</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyDescriptorPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkDescriptorPool</type> <name>descriptorPool</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkResetDescriptorPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkDescriptorPool</type> <name>descriptorPool</name></param>
+ <param optional="true"><type>VkDescriptorPoolResetFlags</type> <name>flags</name></param>
+ <implicitexternsyncparams>
+ <param>any sname:VkDescriptorSet objects allocated from pname:descriptorPool</param>
+ </implicitexternsyncparams>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_FRAGMENTED_POOL,VK_ERROR_OUT_OF_POOL_MEMORY">
+ <proto><type>VkResult</type> <name>vkAllocateDescriptorSets</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pAllocateInfo::descriptorPool">const <type>VkDescriptorSetAllocateInfo</type>* <name>pAllocateInfo</name></param>
+ <param len="pAllocateInfo::descriptorSetCount"><type>VkDescriptorSet</type>* <name>pDescriptorSets</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkFreeDescriptorSets</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkDescriptorPool</type> <name>descriptorPool</name></param>
+ <param><type>uint32_t</type> <name>descriptorSetCount</name></param>
+ <param noautovalidity="true" externsync="true" len="descriptorSetCount">const <type>VkDescriptorSet</type>* <name>pDescriptorSets</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkUpdateDescriptorSets</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true"><type>uint32_t</type> <name>descriptorWriteCount</name></param>
+ <param len="descriptorWriteCount" externsync="pDescriptorWrites[].dstSet">const <type>VkWriteDescriptorSet</type>* <name>pDescriptorWrites</name></param>
+ <param optional="true"><type>uint32_t</type> <name>descriptorCopyCount</name></param>
+ <param len="descriptorCopyCount" externsync="pDescriptorCopies[].dstSet">const <type>VkCopyDescriptorSet</type>* <name>pDescriptorCopies</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateFramebuffer</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkFramebufferCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkFramebuffer</type>* <name>pFramebuffer</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyFramebuffer</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkFramebuffer</type> <name>framebuffer</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateRenderPass</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkRenderPassCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkRenderPass</type>* <name>pRenderPass</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyRenderPass</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkRenderPass</type> <name>renderPass</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetRenderAreaGranularity</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkRenderPass</type> <name>renderPass</name></param>
+ <param><type>VkExtent2D</type>* <name>pGranularity</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateCommandPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkCommandPoolCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkCommandPool</type>* <name>pCommandPool</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyCommandPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkCommandPool</type> <name>commandPool</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkResetCommandPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkCommandPool</type> <name>commandPool</name></param>
+ <param optional="true"><type>VkCommandPoolResetFlags</type> <name>flags</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkAllocateCommandBuffers</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pAllocateInfo::commandPool">const <type>VkCommandBufferAllocateInfo</type>* <name>pAllocateInfo</name></param>
+ <param len="pAllocateInfo::commandBufferCount"><type>VkCommandBuffer</type>* <name>pCommandBuffers</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkFreeCommandBuffers</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkCommandPool</type> <name>commandPool</name></param>
+ <param><type>uint32_t</type> <name>commandBufferCount</name></param>
+ <param noautovalidity="true" externsync="true" len="commandBufferCount">const <type>VkCommandBuffer</type>* <name>pCommandBuffers</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkBeginCommandBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkCommandBufferBeginInfo</type>* <name>pBeginInfo</name></param>
+ <implicitexternsyncparams>
+ <param>the sname:VkCommandPool that pname:commandBuffer was allocated from</param>
+ </implicitexternsyncparams>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkEndCommandBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <implicitexternsyncparams>
+ <param>the sname:VkCommandPool that pname:commandBuffer was allocated from</param>
+ </implicitexternsyncparams>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkResetCommandBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param optional="true"><type>VkCommandBufferResetFlags</type> <name>flags</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdBindPipeline</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineBindPoint</type> <name>pipelineBindPoint</name></param>
+ <param><type>VkPipeline</type> <name>pipeline</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetViewport</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>firstViewport</name></param>
+ <param><type>uint32_t</type> <name>viewportCount</name></param>
+ <param len="viewportCount">const <type>VkViewport</type>* <name>pViewports</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetScissor</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>firstScissor</name></param>
+ <param><type>uint32_t</type> <name>scissorCount</name></param>
+ <param len="scissorCount">const <type>VkRect2D</type>* <name>pScissors</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetLineWidth</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>float</type> <name>lineWidth</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetDepthBias</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>float</type> <name>depthBiasConstantFactor</name></param>
+ <param><type>float</type> <name>depthBiasClamp</name></param>
+ <param><type>float</type> <name>depthBiasSlopeFactor</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetBlendConstants</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>float</type> <name>blendConstants</name>[4]</param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetDepthBounds</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>float</type> <name>minDepthBounds</name></param>
+ <param><type>float</type> <name>maxDepthBounds</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetStencilCompareMask</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkStencilFaceFlags</type> <name>faceMask</name></param>
+ <param><type>uint32_t</type> <name>compareMask</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetStencilWriteMask</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkStencilFaceFlags</type> <name>faceMask</name></param>
+ <param><type>uint32_t</type> <name>writeMask</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetStencilReference</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkStencilFaceFlags</type> <name>faceMask</name></param>
+ <param><type>uint32_t</type> <name>reference</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdBindDescriptorSets</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineBindPoint</type> <name>pipelineBindPoint</name></param>
+ <param><type>VkPipelineLayout</type> <name>layout</name></param>
+ <param><type>uint32_t</type> <name>firstSet</name></param>
+ <param><type>uint32_t</type> <name>descriptorSetCount</name></param>
+ <param len="descriptorSetCount">const <type>VkDescriptorSet</type>* <name>pDescriptorSets</name></param>
+ <param optional="true"><type>uint32_t</type> <name>dynamicOffsetCount</name></param>
+ <param len="dynamicOffsetCount">const <type>uint32_t</type>* <name>pDynamicOffsets</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdBindIndexBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ <param><type>VkIndexType</type> <name>indexType</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdBindVertexBuffers</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>firstBinding</name></param>
+ <param><type>uint32_t</type> <name>bindingCount</name></param>
+ <param len="bindingCount">const <type>VkBuffer</type>* <name>pBuffers</name></param>
+ <param len="bindingCount">const <type>VkDeviceSize</type>* <name>pOffsets</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdDraw</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>vertexCount</name></param>
+ <param><type>uint32_t</type> <name>instanceCount</name></param>
+ <param><type>uint32_t</type> <name>firstVertex</name></param>
+ <param><type>uint32_t</type> <name>firstInstance</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdDrawIndexed</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>indexCount</name></param>
+ <param><type>uint32_t</type> <name>instanceCount</name></param>
+ <param><type>uint32_t</type> <name>firstIndex</name></param>
+ <param><type>int32_t</type> <name>vertexOffset</name></param>
+ <param><type>uint32_t</type> <name>firstInstance</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdDrawIndirect</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ <param><type>uint32_t</type> <name>drawCount</name></param>
+ <param><type>uint32_t</type> <name>stride</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdDrawIndexedIndirect</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ <param><type>uint32_t</type> <name>drawCount</name></param>
+ <param><type>uint32_t</type> <name>stride</name></param>
+ </command>
+ <command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="compute">
+ <proto><type>void</type> <name>vkCmdDispatch</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>groupCountX</name></param>
+ <param><type>uint32_t</type> <name>groupCountY</name></param>
+ <param><type>uint32_t</type> <name>groupCountZ</name></param>
+ </command>
+ <command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="compute">
+ <proto><type>void</type> <name>vkCmdDispatchIndirect</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdCopyBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>srcBuffer</name></param>
+ <param><type>VkBuffer</type> <name>dstBuffer</name></param>
+ <param><type>uint32_t</type> <name>regionCount</name></param>
+ <param len="regionCount">const <type>VkBufferCopy</type>* <name>pRegions</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdCopyImage</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkImage</type> <name>srcImage</name></param>
+ <param><type>VkImageLayout</type> <name>srcImageLayout</name></param>
+ <param><type>VkImage</type> <name>dstImage</name></param>
+ <param><type>VkImageLayout</type> <name>dstImageLayout</name></param>
+ <param><type>uint32_t</type> <name>regionCount</name></param>
+ <param len="regionCount">const <type>VkImageCopy</type>* <name>pRegions</name></param>
+ </command>
+ <command queues="graphics" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdBlitImage</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkImage</type> <name>srcImage</name></param>
+ <param><type>VkImageLayout</type> <name>srcImageLayout</name></param>
+ <param><type>VkImage</type> <name>dstImage</name></param>
+ <param><type>VkImageLayout</type> <name>dstImageLayout</name></param>
+ <param><type>uint32_t</type> <name>regionCount</name></param>
+ <param len="regionCount">const <type>VkImageBlit</type>* <name>pRegions</name></param>
+ <param><type>VkFilter</type> <name>filter</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdCopyBufferToImage</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>srcBuffer</name></param>
+ <param><type>VkImage</type> <name>dstImage</name></param>
+ <param><type>VkImageLayout</type> <name>dstImageLayout</name></param>
+ <param><type>uint32_t</type> <name>regionCount</name></param>
+ <param len="regionCount">const <type>VkBufferImageCopy</type>* <name>pRegions</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdCopyImageToBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkImage</type> <name>srcImage</name></param>
+ <param><type>VkImageLayout</type> <name>srcImageLayout</name></param>
+ <param><type>VkBuffer</type> <name>dstBuffer</name></param>
+ <param><type>uint32_t</type> <name>regionCount</name></param>
+ <param len="regionCount">const <type>VkBufferImageCopy</type>* <name>pRegions</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdUpdateBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>dstBuffer</name></param>
+ <param><type>VkDeviceSize</type> <name>dstOffset</name></param>
+ <param><type>VkDeviceSize</type> <name>dataSize</name></param>
+ <param len="dataSize">const <type>void</type>* <name>pData</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer" comment="transfer support is only available when VK_KHR_maintenance1 is enabled, as documented in valid usage language in the specification">
+ <proto><type>void</type> <name>vkCmdFillBuffer</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>dstBuffer</name></param>
+ <param><type>VkDeviceSize</type> <name>dstOffset</name></param>
+ <param><type>VkDeviceSize</type> <name>size</name></param>
+ <param><type>uint32_t</type> <name>data</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdClearColorImage</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param><type>VkImageLayout</type> <name>imageLayout</name></param>
+ <param>const <type>VkClearColorValue</type>* <name>pColor</name></param>
+ <param><type>uint32_t</type> <name>rangeCount</name></param>
+ <param len="rangeCount">const <type>VkImageSubresourceRange</type>* <name>pRanges</name></param>
+ </command>
+ <command queues="graphics" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdClearDepthStencilImage</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param><type>VkImageLayout</type> <name>imageLayout</name></param>
+ <param>const <type>VkClearDepthStencilValue</type>* <name>pDepthStencil</name></param>
+ <param><type>uint32_t</type> <name>rangeCount</name></param>
+ <param len="rangeCount">const <type>VkImageSubresourceRange</type>* <name>pRanges</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdClearAttachments</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>attachmentCount</name></param>
+ <param len="attachmentCount">const <type>VkClearAttachment</type>* <name>pAttachments</name></param>
+ <param><type>uint32_t</type> <name>rectCount</name></param>
+ <param len="rectCount">const <type>VkClearRect</type>* <name>pRects</name></param>
+ </command>
+ <command queues="graphics" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdResolveImage</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkImage</type> <name>srcImage</name></param>
+ <param><type>VkImageLayout</type> <name>srcImageLayout</name></param>
+ <param><type>VkImage</type> <name>dstImage</name></param>
+ <param><type>VkImageLayout</type> <name>dstImageLayout</name></param>
+ <param><type>uint32_t</type> <name>regionCount</name></param>
+ <param len="regionCount">const <type>VkImageResolve</type>* <name>pRegions</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetEvent</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkEvent</type> <name>event</name></param>
+ <param><type>VkPipelineStageFlags</type> <name>stageMask</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdResetEvent</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkEvent</type> <name>event</name></param>
+ <param><type>VkPipelineStageFlags</type> <name>stageMask</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdWaitEvents</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>eventCount</name></param>
+ <param len="eventCount">const <type>VkEvent</type>* <name>pEvents</name></param>
+ <param><type>VkPipelineStageFlags</type> <name>srcStageMask</name></param>
+ <param><type>VkPipelineStageFlags</type> <name>dstStageMask</name></param>
+ <param optional="true"><type>uint32_t</type> <name>memoryBarrierCount</name></param>
+ <param len="memoryBarrierCount">const <type>VkMemoryBarrier</type>* <name>pMemoryBarriers</name></param>
+ <param optional="true"><type>uint32_t</type> <name>bufferMemoryBarrierCount</name></param>
+ <param len="bufferMemoryBarrierCount">const <type>VkBufferMemoryBarrier</type>* <name>pBufferMemoryBarriers</name></param>
+ <param optional="true"><type>uint32_t</type> <name>imageMemoryBarrierCount</name></param>
+ <param len="imageMemoryBarrierCount">const <type>VkImageMemoryBarrier</type>* <name>pImageMemoryBarriers</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdPipelineBarrier</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineStageFlags</type> <name>srcStageMask</name></param>
+ <param><type>VkPipelineStageFlags</type> <name>dstStageMask</name></param>
+ <param optional="true"><type>VkDependencyFlags</type> <name>dependencyFlags</name></param>
+ <param optional="true"><type>uint32_t</type> <name>memoryBarrierCount</name></param>
+ <param len="memoryBarrierCount">const <type>VkMemoryBarrier</type>* <name>pMemoryBarriers</name></param>
+ <param optional="true"><type>uint32_t</type> <name>bufferMemoryBarrierCount</name></param>
+ <param len="bufferMemoryBarrierCount">const <type>VkBufferMemoryBarrier</type>* <name>pBufferMemoryBarriers</name></param>
+ <param optional="true"><type>uint32_t</type> <name>imageMemoryBarrierCount</name></param>
+ <param len="imageMemoryBarrierCount">const <type>VkImageMemoryBarrier</type>* <name>pImageMemoryBarriers</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdBeginQuery</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param><type>uint32_t</type> <name>query</name></param>
+ <param optional="true"><type>VkQueryControlFlags</type> <name>flags</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdEndQuery</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param><type>uint32_t</type> <name>query</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdResetQueryPool</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param><type>uint32_t</type> <name>firstQuery</name></param>
+ <param><type>uint32_t</type> <name>queryCount</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdWriteTimestamp</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineStageFlagBits</type> <name>pipelineStage</name></param>
+ <param><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param><type>uint32_t</type> <name>query</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="outside" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdCopyQueryPoolResults</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkQueryPool</type> <name>queryPool</name></param>
+ <param><type>uint32_t</type> <name>firstQuery</name></param>
+ <param><type>uint32_t</type> <name>queryCount</name></param>
+ <param><type>VkBuffer</type> <name>dstBuffer</name></param>
+ <param><type>VkDeviceSize</type> <name>dstOffset</name></param>
+ <param><type>VkDeviceSize</type> <name>stride</name></param>
+ <param optional="true"><type>VkQueryResultFlags</type> <name>flags</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdPushConstants</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineLayout</type> <name>layout</name></param>
+ <param><type>VkShaderStageFlags</type> <name>stageFlags</name></param>
+ <param><type>uint32_t</type> <name>offset</name></param>
+ <param><type>uint32_t</type> <name>size</name></param>
+ <param len="size">const <type>void</type>* <name>pValues</name></param>
+ </command>
+ <command queues="graphics" renderpass="outside" cmdbufferlevel="primary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdBeginRenderPass</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkRenderPassBeginInfo</type>* <name>pRenderPassBegin</name></param>
+ <param><type>VkSubpassContents</type> <name>contents</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdNextSubpass</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkSubpassContents</type> <name>contents</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdEndRenderPass</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="both" cmdbufferlevel="primary">
+ <proto><type>void</type> <name>vkCmdExecuteCommands</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>commandBufferCount</name></param>
+ <param len="commandBufferCount">const <type>VkCommandBuffer</type>* <name>pCommandBuffers</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_NATIVE_WINDOW_IN_USE_KHR">
+ <proto><type>VkResult</type> <name>vkCreateAndroidSurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkAndroidSurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceDisplayPropertiesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkDisplayPropertiesKHR</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceDisplayPlanePropertiesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkDisplayPlanePropertiesKHR</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetDisplayPlaneSupportedDisplaysKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>planeIndex</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pDisplayCount</name></param>
+ <param optional="true" len="pDisplayCount"><type>VkDisplayKHR</type>* <name>pDisplays</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetDisplayModePropertiesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkDisplayKHR</type> <name>display</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkDisplayModePropertiesKHR</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INITIALIZATION_FAILED">
+ <proto><type>VkResult</type> <name>vkCreateDisplayModeKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param externsync="true"><type>VkDisplayKHR</type> <name>display</name></param>
+ <param>const <type>VkDisplayModeCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDisplayModeKHR</type>* <name>pMode</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetDisplayPlaneCapabilitiesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param externsync="true"><type>VkDisplayModeKHR</type> <name>mode</name></param>
+ <param><type>uint32_t</type> <name>planeIndex</name></param>
+ <param><type>VkDisplayPlaneCapabilitiesKHR</type>* <name>pCapabilities</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateDisplayPlaneSurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkDisplaySurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INCOMPATIBLE_DISPLAY_KHR,VK_ERROR_DEVICE_LOST,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkCreateSharedSwapchainsKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>swapchainCount</name></param>
+ <param len="swapchainCount" externsync="pCreateInfos[].surface,pCreateInfos[].oldSwapchain">const <type>VkSwapchainCreateInfoKHR</type>* <name>pCreateInfos</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param len="swapchainCount"><type>VkSwapchainKHR</type>* <name>pSwapchains</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateMirSurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkMirSurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command>
+ <proto><type>VkBool32</type> <name>vkGetPhysicalDeviceMirPresentationSupportKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ <param><type>MirConnection</type>* <name>connection</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroySurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param optional="true" externsync="true"><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfaceSupportKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ <param><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param><type>VkBool32</type>* <name>pSupported</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfaceCapabilitiesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param><type>VkSurfaceCapabilitiesKHR</type>* <name>pSurfaceCapabilities</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfaceFormatsKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pSurfaceFormatCount</name></param>
+ <param optional="true" len="pSurfaceFormatCount"><type>VkSurfaceFormatKHR</type>* <name>pSurfaceFormats</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfacePresentModesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPresentModeCount</name></param>
+ <param optional="true" len="pPresentModeCount"><type>VkPresentModeKHR</type>* <name>pPresentModes</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_SURFACE_LOST_KHR,VK_ERROR_NATIVE_WINDOW_IN_USE_KHR">
+ <proto><type>VkResult</type> <name>vkCreateSwapchainKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pCreateInfo.surface,pCreateInfo.oldSwapchain">const <type>VkSwapchainCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSwapchainKHR</type>* <name>pSwapchain</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroySwapchainKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetSwapchainImagesKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pSwapchainImageCount</name></param>
+ <param optional="true" len="pSwapchainImageCount"><type>VkImage</type>* <name>pSwapchainImages</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_TIMEOUT,VK_NOT_READY,VK_SUBOPTIMAL_KHR" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkAcquireNextImageKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ <param><type>uint64_t</type> <name>timeout</name></param>
+ <param optional="true" externsync="true"><type>VkSemaphore</type> <name>semaphore</name></param>
+ <param optional="true" externsync="true"><type>VkFence</type> <name>fence</name></param>
+ <param><type>uint32_t</type>* <name>pImageIndex</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_SUBOPTIMAL_KHR" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkQueuePresentKHR</name></proto>
+ <param externsync="true"><type>VkQueue</type> <name>queue</name></param>
+ <param externsync="pPresentInfo.pWaitSemaphores[],pPresentInfo.pSwapchains[]">const <type>VkPresentInfoKHR</type>* <name>pPresentInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_NATIVE_WINDOW_IN_USE_KHR">
+ <proto><type>VkResult</type> <name>vkCreateViSurfaceNN</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkViSurfaceCreateInfoNN</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateWaylandSurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkWaylandSurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command>
+ <proto><type>VkBool32</type> <name>vkGetPhysicalDeviceWaylandPresentationSupportKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ <param>struct <type>wl_display</type>* <name>display</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateWin32SurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkWin32SurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command>
+ <proto><type>VkBool32</type> <name>vkGetPhysicalDeviceWin32PresentationSupportKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateXlibSurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkXlibSurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command>
+ <proto><type>VkBool32</type> <name>vkGetPhysicalDeviceXlibPresentationSupportKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ <param><type>Display</type>* <name>dpy</name></param>
+ <param><type>VisualID</type> <name>visualID</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateXcbSurfaceKHR</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkXcbSurfaceCreateInfoKHR</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command>
+ <proto><type>VkBool32</type> <name>vkGetPhysicalDeviceXcbPresentationSupportKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>uint32_t</type> <name>queueFamilyIndex</name></param>
+ <param><type>xcb_connection_t</type>* <name>connection</name></param>
+ <param><type>xcb_visualid_t</type> <name>visual_id</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateDebugReportCallbackEXT</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkDebugReportCallbackCreateInfoEXT</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDebugReportCallbackEXT</type>* <name>pCallback</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyDebugReportCallbackEXT</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param externsync="true"><type>VkDebugReportCallbackEXT</type> <name>callback</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDebugReportMessageEXT</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param><type>VkDebugReportFlagsEXT</type> <name>flags</name></param>
+ <param><type>VkDebugReportObjectTypeEXT</type> <name>objectType</name></param>
+ <param><type>uint64_t</type> <name>object</name></param>
+ <param><type>size_t</type> <name>location</name></param>
+ <param><type>int32_t</type> <name>messageCode</name></param>
+ <param len="null-terminated">const <type>char</type>* <name>pLayerPrefix</name></param>
+ <param len="null-terminated">const <type>char</type>* <name>pMessage</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkDebugMarkerSetObjectNameEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pNameInfo.object">const <type>VkDebugMarkerObjectNameInfoEXT</type>* <name>pNameInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkDebugMarkerSetObjectTagEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pTagInfo.object">const <type>VkDebugMarkerObjectTagInfoEXT</type>* <name>pTagInfo</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdDebugMarkerBeginEXT</name></proto>
+ <param><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkDebugMarkerMarkerInfoEXT</type>* <name>pMarkerInfo</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdDebugMarkerEndEXT</name></proto>
+ <param><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdDebugMarkerInsertEXT</name></proto>
+ <param><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkDebugMarkerMarkerInfoEXT</type>* <name>pMarkerInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_FORMAT_NOT_SUPPORTED">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceExternalImageFormatPropertiesNV</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkFormat</type> <name>format</name></param>
+ <param><type>VkImageType</type> <name>type</name></param>
+ <param><type>VkImageTiling</type> <name>tiling</name></param>
+ <param><type>VkImageUsageFlags</type> <name>usage</name></param>
+ <param optional="true"><type>VkImageCreateFlags</type> <name>flags</name></param>
+ <param optional="true"><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>externalHandleType</name></param>
+ <param><type>VkExternalImageFormatPropertiesNV</type>* <name>pExternalImageFormatProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetMemoryWin32HandleNV</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkDeviceMemory</type> <name>memory</name></param>
+ <param><type>VkExternalMemoryHandleTypeFlagsNV</type> <name>handleType</name></param>
+ <param><type>HANDLE</type>* <name>pHandle</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdDrawIndirectCountAMD</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ <param><type>VkBuffer</type> <name>countBuffer</name></param>
+ <param><type>VkDeviceSize</type> <name>countBufferOffset</name></param>
+ <param><type>uint32_t</type> <name>maxDrawCount</name></param>
+ <param><type>uint32_t</type> <name>stride</name></param>
+ </command>
+ <command queues="graphics" renderpass="inside" cmdbufferlevel="primary,secondary" pipeline="graphics">
+ <proto><type>void</type> <name>vkCmdDrawIndexedIndirectCountAMD</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkBuffer</type> <name>buffer</name></param>
+ <param><type>VkDeviceSize</type> <name>offset</name></param>
+ <param><type>VkBuffer</type> <name>countBuffer</name></param>
+ <param><type>VkDeviceSize</type> <name>countBufferOffset</name></param>
+ <param><type>uint32_t</type> <name>maxDrawCount</name></param>
+ <param><type>uint32_t</type> <name>stride</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="inside" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdProcessCommandsNVX</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkCmdProcessCommandsInfoNVX</type>* <name>pProcessCommandsInfo</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="inside" cmdbufferlevel="secondary">
+ <proto><type>void</type> <name>vkCmdReserveSpaceForCommandsNVX</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkCmdReserveSpaceForCommandsInfoNVX</type>* <name>pReserveSpaceInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateIndirectCommandsLayoutNVX</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkIndirectCommandsLayoutCreateInfoNVX</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkIndirectCommandsLayoutNVX</type>* <name>pIndirectCommandsLayout</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyIndirectCommandsLayoutNVX</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkIndirectCommandsLayoutNVX</type> <name>indirectCommandsLayout</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateObjectTableNVX</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkObjectTableCreateInfoNVX</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkObjectTableNVX</type>* <name>pObjectTable</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyObjectTableNVX</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkObjectTableNVX</type> <name>objectTable</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkRegisterObjectsNVX</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkObjectTableNVX</type> <name>objectTable</name></param>
+ <param><type>uint32_t</type> <name>objectCount</name></param>
+ <param len="objectCount">const <type>VkObjectTableEntryNVX</type>* const* <name>ppObjectTableEntries</name></param>
+ <param len="objectCount">const <type>uint32_t</type>* <name>pObjectIndices</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkUnregisterObjectsNVX</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkObjectTableNVX</type> <name>objectTable</name></param>
+ <param><type>uint32_t</type> <name>objectCount</name></param>
+ <param len="objectCount">const <type>VkObjectEntryTypeNVX</type>* <name>pObjectEntryTypes</name></param>
+ <param len="objectCount">const <type>uint32_t</type>* <name>pObjectIndices</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkDeviceGeneratedCommandsFeaturesNVX</type>* <name>pFeatures</name></param>
+ <param><type>VkDeviceGeneratedCommandsLimitsNVX</type>* <name>pLimits</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceFeatures2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkPhysicalDeviceFeatures2</type>* <name>pFeatures</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceFeatures2KHR" alias="vkGetPhysicalDeviceFeatures2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceProperties2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkPhysicalDeviceProperties2</type>* <name>pProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceProperties2KHR" alias="vkGetPhysicalDeviceProperties2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceFormatProperties2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkFormat</type> <name>format</name></param>
+ <param><type>VkFormatProperties2</type>* <name>pFormatProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceFormatProperties2KHR" alias="vkGetPhysicalDeviceFormatProperties2"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_FORMAT_NOT_SUPPORTED">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceImageFormatProperties2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceImageFormatInfo2</type>* <name>pImageFormatInfo</name></param>
+ <param><type>VkImageFormatProperties2</type>* <name>pImageFormatProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceImageFormatProperties2KHR" alias="vkGetPhysicalDeviceImageFormatProperties2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceQueueFamilyProperties2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pQueueFamilyPropertyCount</name></param>
+ <param optional="true" len="pQueueFamilyPropertyCount"><type>VkQueueFamilyProperties2</type>* <name>pQueueFamilyProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceQueueFamilyProperties2KHR" alias="vkGetPhysicalDeviceQueueFamilyProperties2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceMemoryProperties2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkPhysicalDeviceMemoryProperties2</type>* <name>pMemoryProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceMemoryProperties2KHR" alias="vkGetPhysicalDeviceMemoryProperties2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceSparseImageFormatProperties2</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceSparseImageFormatInfo2</type>* <name>pFormatInfo</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPropertyCount</name></param>
+ <param optional="true" len="pPropertyCount"><type>VkSparseImageFormatProperties2</type>* <name>pProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceSparseImageFormatProperties2KHR" alias="vkGetPhysicalDeviceSparseImageFormatProperties2"/>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdPushDescriptorSetKHR</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineBindPoint</type> <name>pipelineBindPoint</name></param>
+ <param><type>VkPipelineLayout</type> <name>layout</name></param>
+ <param><type>uint32_t</type> <name>set</name></param>
+ <param><type>uint32_t</type> <name>descriptorWriteCount</name></param>
+ <param len="descriptorWriteCount">const <type>VkWriteDescriptorSet</type>* <name>pDescriptorWrites</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkTrimCommandPool</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkCommandPool</type> <name>commandPool</name></param>
+ <param optional="true"><type>VkCommandPoolTrimFlags</type> <name>flags</name></param>
+ </command>
+ <command name="vkTrimCommandPoolKHR" alias="vkTrimCommandPool"/>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceExternalBufferProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceExternalBufferInfo</type>* <name>pExternalBufferInfo</name></param>
+ <param><type>VkExternalBufferProperties</type>* <name>pExternalBufferProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceExternalBufferPropertiesKHR" alias="vkGetPhysicalDeviceExternalBufferProperties"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetMemoryWin32HandleKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkMemoryGetWin32HandleInfoKHR</type>* <name>pGetWin32HandleInfo</name></param>
+ <param><type>HANDLE</type>* <name>pHandle</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkGetMemoryWin32HandlePropertiesKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></param>
+ <param><type>HANDLE</type> <name>handle</name></param>
+ <param><type>VkMemoryWin32HandlePropertiesKHR</type>* <name>pMemoryWin32HandleProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetMemoryFdKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkMemoryGetFdInfoKHR</type>* <name>pGetFdInfo</name></param>
+ <param><type>int</type>* <name>pFd</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkGetMemoryFdPropertiesKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></param>
+ <param><type>int</type> <name>fd</name></param>
+ <param><type>VkMemoryFdPropertiesKHR</type>* <name>pMemoryFdProperties</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceExternalSemaphoreProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceExternalSemaphoreInfo</type>* <name>pExternalSemaphoreInfo</name></param>
+ <param><type>VkExternalSemaphoreProperties</type>* <name>pExternalSemaphoreProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceExternalSemaphorePropertiesKHR" alias="vkGetPhysicalDeviceExternalSemaphoreProperties"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetSemaphoreWin32HandleKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkSemaphoreGetWin32HandleInfoKHR</type>* <name>pGetWin32HandleInfo</name></param>
+ <param><type>HANDLE</type>* <name>pHandle</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkImportSemaphoreWin32HandleKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImportSemaphoreWin32HandleInfoKHR</type>* <name>pImportSemaphoreWin32HandleInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetSemaphoreFdKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkSemaphoreGetFdInfoKHR</type>* <name>pGetFdInfo</name></param>
+ <param><type>int</type>* <name>pFd</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkImportSemaphoreFdKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImportSemaphoreFdInfoKHR</type>* <name>pImportSemaphoreFdInfo</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceExternalFenceProperties</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceExternalFenceInfo</type>* <name>pExternalFenceInfo</name></param>
+ <param><type>VkExternalFenceProperties</type>* <name>pExternalFenceProperties</name></param>
+ </command>
+ <command name="vkGetPhysicalDeviceExternalFencePropertiesKHR" alias="vkGetPhysicalDeviceExternalFenceProperties"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetFenceWin32HandleKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkFenceGetWin32HandleInfoKHR</type>* <name>pGetWin32HandleInfo</name></param>
+ <param><type>HANDLE</type>* <name>pHandle</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkImportFenceWin32HandleKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImportFenceWin32HandleInfoKHR</type>* <name>pImportFenceWin32HandleInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetFenceFdKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkFenceGetFdInfoKHR</type>* <name>pGetFdInfo</name></param>
+ <param><type>int</type>* <name>pFd</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkImportFenceFdKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImportFenceFdInfoKHR</type>* <name>pImportFenceFdInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS">
+ <proto><type>VkResult</type> <name>vkReleaseDisplayEXT</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkDisplayKHR</type> <name>display</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_INITIALIZATION_FAILED">
+ <proto><type>VkResult</type> <name>vkAcquireXlibDisplayEXT</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>Display</type>* <name>dpy</name></param>
+ <param><type>VkDisplayKHR</type> <name>display</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS">
+ <proto><type>VkResult</type> <name>vkGetRandROutputDisplayEXT</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>Display</type>* <name>dpy</name></param>
+ <param><type>RROutput</type> <name>rrOutput</name></param>
+ <param><type>VkDisplayKHR</type>* <name>pDisplay</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS">
+ <proto><type>VkResult</type> <name>vkDisplayPowerControlEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkDisplayKHR</type> <name>display</name></param>
+ <param>const <type>VkDisplayPowerInfoEXT</type>* <name>pDisplayPowerInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS">
+ <proto><type>VkResult</type> <name>vkRegisterDeviceEventEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkDeviceEventInfoEXT</type>* <name>pDeviceEventInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkFence</type>* <name>pFence</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS">
+ <proto><type>VkResult</type> <name>vkRegisterDisplayEventEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkDisplayKHR</type> <name>display</name></param>
+ <param>const <type>VkDisplayEventInfoEXT</type>* <name>pDisplayEventInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkFence</type>* <name>pFence</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR">
+ <proto><type>VkResult</type> <name>vkGetSwapchainCounterEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ <param><type>VkSurfaceCounterFlagBitsEXT</type> <name>counter</name></param>
+ <param><type>uint64_t</type>* <name>pCounterValue</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfaceCapabilities2EXT</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param><type>VkSurfaceCapabilities2EXT</type>* <name>pSurfaceCapabilities</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_INITIALIZATION_FAILED">
+ <proto><type>VkResult</type> <name>vkEnumeratePhysicalDeviceGroups</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPhysicalDeviceGroupCount</name></param>
+ <param optional="true" len="pPhysicalDeviceGroupCount"><type>VkPhysicalDeviceGroupProperties</type>* <name>pPhysicalDeviceGroupProperties</name></param>
+ </command>
+ <command name="vkEnumeratePhysicalDeviceGroupsKHR" alias="vkEnumeratePhysicalDeviceGroups"/>
+ <command>
+ <proto><type>void</type> <name>vkGetDeviceGroupPeerMemoryFeatures</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>heapIndex</name></param>
+ <param><type>uint32_t</type> <name>localDeviceIndex</name></param>
+ <param><type>uint32_t</type> <name>remoteDeviceIndex</name></param>
+ <param><type>VkPeerMemoryFeatureFlags</type>* <name>pPeerMemoryFeatures</name></param>
+ </command>
+ <command name="vkGetDeviceGroupPeerMemoryFeaturesKHR" alias="vkGetDeviceGroupPeerMemoryFeatures"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkBindBufferMemory2</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>bindInfoCount</name></param>
+ <param len="bindInfoCount">const <type>VkBindBufferMemoryInfo</type>* <name>pBindInfos</name></param>
+ </command>
+ <command name="vkBindBufferMemory2KHR" alias="vkBindBufferMemory2"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkBindImageMemory2</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>bindInfoCount</name></param>
+ <param len="bindInfoCount">const <type>VkBindImageMemoryInfo</type>* <name>pBindInfos</name></param>
+ </command>
+ <command name="vkBindImageMemory2KHR" alias="vkBindImageMemory2"/>
+ <command queues="graphics,compute,transfer" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetDeviceMask</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>deviceMask</name></param>
+ </command>
+ <command name="vkCmdSetDeviceMaskKHR" alias="vkCmdSetDeviceMask"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetDeviceGroupPresentCapabilitiesKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkDeviceGroupPresentCapabilitiesKHR</type>* <name>pDeviceGroupPresentCapabilities</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetDeviceGroupSurfacePresentModesKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param optional="false,true"><type>VkDeviceGroupPresentModeFlagsKHR</type>* <name>pModes</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_TIMEOUT,VK_NOT_READY,VK_SUBOPTIMAL_KHR" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkAcquireNextImage2KHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkAcquireNextImageInfoKHR</type>* <name>pAcquireInfo</name></param>
+ <param><type>uint32_t</type>* <name>pImageIndex</name></param>
+ </command>
+ <command queues="compute" renderpass="outside" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdDispatchBase</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>baseGroupX</name></param>
+ <param><type>uint32_t</type> <name>baseGroupY</name></param>
+ <param><type>uint32_t</type> <name>baseGroupZ</name></param>
+ <param><type>uint32_t</type> <name>groupCountX</name></param>
+ <param><type>uint32_t</type> <name>groupCountY</name></param>
+ <param><type>uint32_t</type> <name>groupCountZ</name></param>
+ </command>
+ <command name="vkCmdDispatchBaseKHR" alias="vkCmdDispatchBase"/>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDevicePresentRectanglesKHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param externsync="true"><type>VkSurfaceKHR</type> <name>surface</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pRectCount</name></param>
+ <param optional="true" len="pRectCount"><type>VkRect2D</type>* <name>pRects</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateDescriptorUpdateTemplate</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkDescriptorUpdateTemplateCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDescriptorUpdateTemplate</type>* <name>pDescriptorUpdateTemplate</name></param>
+ </command>
+ <command name="vkCreateDescriptorUpdateTemplateKHR" alias="vkCreateDescriptorUpdateTemplate"/>
+ <command>
+ <proto><type>void</type> <name>vkDestroyDescriptorUpdateTemplate</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkDescriptorUpdateTemplate</type> <name>descriptorUpdateTemplate</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command name="vkDestroyDescriptorUpdateTemplateKHR" alias="vkDestroyDescriptorUpdateTemplate"/>
+ <command>
+ <proto><type>void</type> <name>vkUpdateDescriptorSetWithTemplate</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkDescriptorSet</type> <name>descriptorSet</name></param>
+ <param><type>VkDescriptorUpdateTemplate</type> <name>descriptorUpdateTemplate</name></param>
+ <param noautovalidity="true">const <type>void</type>* <name>pData</name></param>
+ </command>
+ <command name="vkUpdateDescriptorSetWithTemplateKHR" alias="vkUpdateDescriptorSetWithTemplate"/>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdPushDescriptorSetWithTemplateKHR</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkDescriptorUpdateTemplate</type> <name>descriptorUpdateTemplate</name></param>
+ <param><type>VkPipelineLayout</type> <name>layout</name></param>
+ <param><type>uint32_t</type> <name>set</name></param>
+ <param noautovalidity="true">const <type>void</type>* <name>pData</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkSetHdrMetadataEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>uint32_t</type> <name>swapchainCount</name></param>
+ <param len="swapchainCount">const <type>VkSwapchainKHR</type>* <name>pSwapchains</name></param>
+ <param len="swapchainCount">const <type>VkHdrMetadataEXT</type>* <name>pMetadata</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_SUBOPTIMAL_KHR" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetSwapchainStatusKHR</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_DEVICE_LOST,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetRefreshCycleDurationGOOGLE</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ <param><type>VkRefreshCycleDurationGOOGLE</type>* <name>pDisplayTimingProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_DEVICE_LOST,VK_ERROR_OUT_OF_DATE_KHR,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPastPresentationTimingGOOGLE</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkSwapchainKHR</type> <name>swapchain</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pPresentationTimingCount</name></param>
+ <param optional="true" len="pPresentationTimingCount"><type>VkPastPresentationTimingGOOGLE</type>* <name>pPresentationTimings</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_NATIVE_WINDOW_IN_USE_KHR">
+ <proto><type>VkResult</type> <name>vkCreateIOSSurfaceMVK</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkIOSSurfaceCreateInfoMVK</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_NATIVE_WINDOW_IN_USE_KHR">
+ <proto><type>VkResult</type> <name>vkCreateMacOSSurfaceMVK</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkMacOSSurfaceCreateInfoMVK</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSurfaceKHR</type>* <name>pSurface</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetViewportWScalingNV</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>firstViewport</name></param>
+ <param><type>uint32_t</type> <name>viewportCount</name></param>
+ <param len="viewportCount">const <type>VkViewportWScalingNV</type>* <name>pViewportWScalings</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetDiscardRectangleEXT</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>uint32_t</type> <name>firstDiscardRectangle</name></param>
+ <param><type>uint32_t</type> <name>discardRectangleCount</name></param>
+ <param len="discardRectangleCount">const <type>VkRect2D</type>* <name>pDiscardRectangles</name></param>
+ </command>
+ <command queues="graphics" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdSetSampleLocationsEXT</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkSampleLocationsInfoEXT</type>* <name>pSampleLocationsInfo</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetPhysicalDeviceMultisamplePropertiesEXT</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param><type>VkSampleCountFlagBits</type> <name>samples</name></param>
+ <param><type>VkMultisamplePropertiesEXT</type>* <name>pMultisampleProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfaceCapabilities2KHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceSurfaceInfo2KHR</type>* <name>pSurfaceInfo</name></param>
+ <param><type>VkSurfaceCapabilities2KHR</type>* <name>pSurfaceCapabilities</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY,VK_ERROR_SURFACE_LOST_KHR">
+ <proto><type>VkResult</type> <name>vkGetPhysicalDeviceSurfaceFormats2KHR</name></proto>
+ <param><type>VkPhysicalDevice</type> <name>physicalDevice</name></param>
+ <param>const <type>VkPhysicalDeviceSurfaceInfo2KHR</type>* <name>pSurfaceInfo</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pSurfaceFormatCount</name></param>
+ <param optional="true" len="pSurfaceFormatCount"><type>VkSurfaceFormat2KHR</type>* <name>pSurfaceFormats</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetBufferMemoryRequirements2</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkBufferMemoryRequirementsInfo2</type>* <name>pInfo</name></param>
+ <param><type>VkMemoryRequirements2</type>* <name>pMemoryRequirements</name></param>
+ </command>
+ <command name="vkGetBufferMemoryRequirements2KHR" alias="vkGetBufferMemoryRequirements2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetImageMemoryRequirements2</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImageMemoryRequirementsInfo2</type>* <name>pInfo</name></param>
+ <param><type>VkMemoryRequirements2</type>* <name>pMemoryRequirements</name></param>
+ </command>
+ <command name="vkGetImageMemoryRequirements2KHR" alias="vkGetImageMemoryRequirements2"/>
+ <command>
+ <proto><type>void</type> <name>vkGetImageSparseMemoryRequirements2</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkImageSparseMemoryRequirementsInfo2</type>* <name>pInfo</name></param>
+ <param optional="false,true"><type>uint32_t</type>* <name>pSparseMemoryRequirementCount</name></param>
+ <param optional="true" len="pSparseMemoryRequirementCount"><type>VkSparseImageMemoryRequirements2</type>* <name>pSparseMemoryRequirements</name></param>
+ </command>
+ <command name="vkGetImageSparseMemoryRequirements2KHR" alias="vkGetImageSparseMemoryRequirements2"/>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateSamplerYcbcrConversion</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkSamplerYcbcrConversionCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkSamplerYcbcrConversion</type>* <name>pYcbcrConversion</name></param>
+ </command>
+ <command name="vkCreateSamplerYcbcrConversionKHR" alias="vkCreateSamplerYcbcrConversion"/>
+ <command>
+ <proto><type>void</type> <name>vkDestroySamplerYcbcrConversion</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkSamplerYcbcrConversion</type> <name>ycbcrConversion</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command name="vkDestroySamplerYcbcrConversionKHR" alias="vkDestroySamplerYcbcrConversion"/>
+ <command>
+ <proto><type>void</type> <name>vkGetDeviceQueue2</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkDeviceQueueInfo2</type>* <name>pQueueInfo</name></param>
+ <param><type>VkQueue</type>* <name>pQueue</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateValidationCacheEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkValidationCacheCreateInfoEXT</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkValidationCacheEXT</type>* <name>pValidationCache</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyValidationCacheEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param optional="true" externsync="true"><type>VkValidationCacheEXT</type> <name>validationCache</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetValidationCacheDataEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkValidationCacheEXT</type> <name>validationCache</name></param>
+ <param optional="false,true"><type>size_t</type>* <name>pDataSize</name></param>
+ <param optional="true" len="pDataSize"><type>void</type>* <name>pData</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkMergeValidationCachesEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="true"><type>VkValidationCacheEXT</type> <name>dstCache</name></param>
+ <param><type>uint32_t</type> <name>srcCacheCount</name></param>
+ <param len="srcCacheCount">const <type>VkValidationCacheEXT</type>* <name>pSrcCaches</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkGetDescriptorSetLayoutSupport</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkDescriptorSetLayoutCreateInfo</type>* <name>pCreateInfo</name></param>
+ <param><type>VkDescriptorSetLayoutSupport</type>* <name>pSupport</name></param>
+ </command>
+ <command name="vkGetDescriptorSetLayoutSupportKHR" alias="vkGetDescriptorSetLayoutSupport"/>
+ <command>
+ <proto><type>VkResult</type> <name>vkGetSwapchainGrallocUsageANDROID</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkFormat</type> <name>format</name></param>
+ <param><type>VkImageUsageFlags</type> <name>imageUsage</name></param>
+ <param><type>int</type>* <name>grallocUsage</name></param>
+ </command>
+ <command>
+ <proto><type>VkResult</type> <name>vkAcquireImageANDROID</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param><type>int</type> <name>nativeFenceFd</name></param>
+ <param><type>VkSemaphore</type> <name>semaphore</name></param>
+ <param><type>VkFence</type> <name>fence</name></param>
+ </command>
+ <command>
+ <proto><type>VkResult</type> <name>vkQueueSignalReleaseImageANDROID</name></proto>
+ <param><type>VkQueue</type> <name>queue</name></param>
+ <param><type>uint32_t</type> <name>waitSemaphoreCount</name></param>
+ <param>const <type>VkSemaphore</type>* <name>pWaitSemaphores</name></param>
+ <param><type>VkImage</type> <name>image</name></param>
+ <param><type>int</type>* <name>pNativeFenceFd</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS,VK_INCOMPLETE" errorcodes="VK_ERROR_FEATURE_NOT_PRESENT,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetShaderInfoAMD</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkPipeline</type> <name>pipeline</name></param>
+ <param><type>VkShaderStageFlagBits</type> <name>shaderStage</name></param>
+ <param><type>VkShaderInfoTypeAMD</type> <name>infoType</name></param>
+ <param optional="false,true"><type>size_t</type>* <name>pInfoSize</name></param>
+ <param optional="true" len="pInfoSize"><type>void</type>* <name>pInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkSetDebugUtilsObjectNameEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pNameInfo.objectHandle">const <type>VkDebugUtilsObjectNameInfoEXT</type>* <name>pNameInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY,VK_ERROR_OUT_OF_DEVICE_MEMORY">
+ <proto><type>VkResult</type> <name>vkSetDebugUtilsObjectTagEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param externsync="pTagInfo.objectHandle">const <type>VkDebugUtilsObjectTagInfoEXT</type>* <name>pTagInfo</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkQueueBeginDebugUtilsLabelEXT</name></proto>
+ <param><type>VkQueue</type> <name>queue</name></param>
+ <param>const <type>VkDebugUtilsLabelEXT</type>* <name>pLabelInfo</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkQueueEndDebugUtilsLabelEXT</name></proto>
+ <param><type>VkQueue</type> <name>queue</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkQueueInsertDebugUtilsLabelEXT</name></proto>
+ <param><type>VkQueue</type> <name>queue</name></param>
+ <param>const <type>VkDebugUtilsLabelEXT</type>* <name>pLabelInfo</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdBeginDebugUtilsLabelEXT</name></proto>
+ <param><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkDebugUtilsLabelEXT</type>* <name>pLabelInfo</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdEndDebugUtilsLabelEXT</name></proto>
+ <param><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ </command>
+ <command queues="graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary">
+ <proto><type>void</type> <name>vkCmdInsertDebugUtilsLabelEXT</name></proto>
+ <param><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param>const <type>VkDebugUtilsLabelEXT</type>* <name>pLabelInfo</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkCreateDebugUtilsMessengerEXT</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param>const <type>VkDebugUtilsMessengerCreateInfoEXT</type>* <name>pCreateInfo</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ <param><type>VkDebugUtilsMessengerEXT</type>* <name>pMessenger</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkDestroyDebugUtilsMessengerEXT</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param externsync="true"><type>VkDebugUtilsMessengerEXT</type> <name>messenger</name></param>
+ <param optional="true">const <type>VkAllocationCallbacks</type>* <name>pAllocator</name></param>
+ </command>
+ <command>
+ <proto><type>void</type> <name>vkSubmitDebugUtilsMessageEXT</name></proto>
+ <param><type>VkInstance</type> <name>instance</name></param>
+ <param><type>VkDebugUtilsMessageSeverityFlagBitsEXT</type> <name>messageSeverity</name></param>
+ <param><type>VkDebugUtilsMessageTypeFlagsEXT</type> <name>messageTypes</name></param>
+ <param>const <type>VkDebugUtilsMessengerCallbackDataEXT</type>* <name>pCallbackData</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_INVALID_EXTERNAL_HANDLE">
+ <proto><type>VkResult</type> <name>vkGetMemoryHostPointerPropertiesEXT</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param><type>VkExternalMemoryHandleTypeFlagBits</type> <name>handleType</name></param>
+ <param optional="false">const <type>void</type>* <name>pHostPointer</name></param>
+ <param><type>VkMemoryHostPointerPropertiesEXT</type>* <name>pMemoryHostPointerProperties</name></param>
+ </command>
+ <command queues="transfer,graphics,compute" renderpass="both" cmdbufferlevel="primary,secondary" pipeline="transfer">
+ <proto><type>void</type> <name>vkCmdWriteBufferMarkerAMD</name></proto>
+ <param externsync="true"><type>VkCommandBuffer</type> <name>commandBuffer</name></param>
+ <param><type>VkPipelineStageFlagBits</type> <name>pipelineStage</name></param>
+ <param><type>VkBuffer</type> <name>dstBuffer</name></param>
+ <param><type>VkDeviceSize</type> <name>dstOffset</name></param>
+ <param><type>uint32_t</type> <name>marker</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_INVALID_EXTERNAL_HANDLE_KHR">
+ <proto><type>VkResult</type> <name>vkGetAndroidHardwareBufferPropertiesANDROID</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const struct <type>AHardwareBuffer</type>* <name>buffer</name></param>
+ <param><type>VkAndroidHardwareBufferPropertiesANDROID</type>* <name>pProperties</name></param>
+ </command>
+ <command successcodes="VK_SUCCESS" errorcodes="VK_ERROR_TOO_MANY_OBJECTS,VK_ERROR_OUT_OF_HOST_MEMORY">
+ <proto><type>VkResult</type> <name>vkGetMemoryAndroidHardwareBufferANDROID</name></proto>
+ <param><type>VkDevice</type> <name>device</name></param>
+ <param>const <type>VkMemoryGetAndroidHardwareBufferInfoANDROID</type>* <name>pInfo</name></param>
+ <param>struct <type>AHardwareBuffer</type>** <name>pBuffer</name></param>
+ </command>
+ </commands>
+
+ <feature api="vulkan" name="VK_VERSION_1_0" number="1.0" comment="Vulkan core API interface definitions">
+ <require comment="Header boilerplate">
+ <type name="vk_platform"/>
+ </require>
+ <require comment="API version">
+ <type name="VK_API_VERSION"/>
+ <type name="VK_API_VERSION_1_0"/>
+ <type name="VK_VERSION_MAJOR"/>
+ <type name="VK_VERSION_MINOR"/>
+ <type name="VK_VERSION_PATCH"/>
+ <type name="VK_HEADER_VERSION"/>
+ </require>
+ <require comment="API constants">
+ <enum name="VK_LOD_CLAMP_NONE"/>
+ <enum name="VK_REMAINING_MIP_LEVELS"/>
+ <enum name="VK_REMAINING_ARRAY_LAYERS"/>
+ <enum name="VK_WHOLE_SIZE"/>
+ <enum name="VK_ATTACHMENT_UNUSED"/>
+ <enum name="VK_TRUE"/>
+ <enum name="VK_FALSE"/>
+ <type name="VK_NULL_HANDLE"/>
+ <enum name="VK_QUEUE_FAMILY_IGNORED"/>
+ <enum name="VK_SUBPASS_EXTERNAL"/>
+ <type name="VkPipelineCacheHeaderVersion"/>
+ </require>
+ <require comment="Device initialization">
+ <command name="vkCreateInstance"/>
+ <command name="vkDestroyInstance"/>
+ <command name="vkEnumeratePhysicalDevices"/>
+ <command name="vkGetPhysicalDeviceFeatures"/>
+ <command name="vkGetPhysicalDeviceFormatProperties"/>
+ <command name="vkGetPhysicalDeviceImageFormatProperties"/>
+ <command name="vkGetPhysicalDeviceProperties"/>
+ <command name="vkGetPhysicalDeviceQueueFamilyProperties"/>
+ <command name="vkGetPhysicalDeviceMemoryProperties"/>
+ <command name="vkGetInstanceProcAddr"/>
+ <command name="vkGetDeviceProcAddr"/>
+ </require>
+ <require comment="Device commands">
+ <command name="vkCreateDevice"/>
+ <command name="vkDestroyDevice"/>
+ </require>
+ <require comment="Extension discovery commands">
+ <command name="vkEnumerateInstanceExtensionProperties"/>
+ <command name="vkEnumerateDeviceExtensionProperties"/>
+ </require>
+ <require comment="Layer discovery commands">
+ <command name="vkEnumerateInstanceLayerProperties"/>
+ <command name="vkEnumerateDeviceLayerProperties"/>
+ </require>
+ <require comment="queue commands">
+ <command name="vkGetDeviceQueue"/>
+ <command name="vkQueueSubmit"/>
+ <command name="vkQueueWaitIdle"/>
+ <command name="vkDeviceWaitIdle"/>
+ </require>
+ <require comment="Memory commands">
+ <command name="vkAllocateMemory"/>
+ <command name="vkFreeMemory"/>
+ <command name="vkMapMemory"/>
+ <command name="vkUnmapMemory"/>
+ <command name="vkFlushMappedMemoryRanges"/>
+ <command name="vkInvalidateMappedMemoryRanges"/>
+ <command name="vkGetDeviceMemoryCommitment"/>
+ </require>
+ <require comment="Memory management API commands">
+ <command name="vkBindBufferMemory"/>
+ <command name="vkBindImageMemory"/>
+ <command name="vkGetBufferMemoryRequirements"/>
+ <command name="vkGetImageMemoryRequirements"/>
+ </require>
+ <require comment="Sparse resource memory management API commands">
+ <command name="vkGetImageSparseMemoryRequirements"/>
+ <command name="vkGetPhysicalDeviceSparseImageFormatProperties"/>
+ <command name="vkQueueBindSparse"/>
+ </require>
+ <require comment="Fence commands">
+ <command name="vkCreateFence"/>
+ <command name="vkDestroyFence"/>
+ <command name="vkResetFences"/>
+ <command name="vkGetFenceStatus"/>
+ <command name="vkWaitForFences"/>
+ </require>
+ <require comment="Queue semaphore commands">
+ <command name="vkCreateSemaphore"/>
+ <command name="vkDestroySemaphore"/>
+ </require>
+ <require comment="Event commands">
+ <command name="vkCreateEvent"/>
+ <command name="vkDestroyEvent"/>
+ <command name="vkGetEventStatus"/>
+ <command name="vkSetEvent"/>
+ <command name="vkResetEvent"/>
+ </require>
+ <require comment="Query commands">
+ <command name="vkCreateQueryPool"/>
+ <command name="vkDestroyQueryPool"/>
+ <command name="vkGetQueryPoolResults"/>
+ </require>
+ <require comment="Buffer commands">
+ <command name="vkCreateBuffer"/>
+ <command name="vkDestroyBuffer"/>
+ </require>
+ <require comment="Buffer view commands">
+ <command name="vkCreateBufferView"/>
+ <command name="vkDestroyBufferView"/>
+ </require>
+ <require comment="Image commands">
+ <command name="vkCreateImage"/>
+ <command name="vkDestroyImage"/>
+ <command name="vkGetImageSubresourceLayout"/>
+ </require>
+ <require comment="Image view commands">
+ <command name="vkCreateImageView"/>
+ <command name="vkDestroyImageView"/>
+ </require>
+ <require comment="Shader commands">
+ <command name="vkCreateShaderModule"/>
+ <command name="vkDestroyShaderModule"/>
+ </require>
+ <require comment="Pipeline Cache commands">
+ <command name="vkCreatePipelineCache"/>
+ <command name="vkDestroyPipelineCache"/>
+ <command name="vkGetPipelineCacheData"/>
+ <command name="vkMergePipelineCaches"/>
+ </require>
+ <require comment="Pipeline commands">
+ <command name="vkCreateGraphicsPipelines"/>
+ <command name="vkCreateComputePipelines"/>
+ <command name="vkDestroyPipeline"/>
+ </require>
+ <require comment="Pipeline layout commands">
+ <command name="vkCreatePipelineLayout"/>
+ <command name="vkDestroyPipelineLayout"/>
+ </require>
+ <require comment="Sampler commands">
+ <command name="vkCreateSampler"/>
+ <command name="vkDestroySampler"/>
+ </require>
+ <require comment="Descriptor set commands">
+ <command name="vkCreateDescriptorSetLayout"/>
+ <command name="vkDestroyDescriptorSetLayout"/>
+ <command name="vkCreateDescriptorPool"/>
+ <command name="vkDestroyDescriptorPool"/>
+ <command name="vkResetDescriptorPool"/>
+ <command name="vkAllocateDescriptorSets"/>
+ <command name="vkFreeDescriptorSets"/>
+ <command name="vkUpdateDescriptorSets"/>
+ </require>
+ <require comment="Pass commands">
+ <command name="vkCreateFramebuffer"/>
+ <command name="vkDestroyFramebuffer"/>
+ <command name="vkCreateRenderPass"/>
+ <command name="vkDestroyRenderPass"/>
+ <command name="vkGetRenderAreaGranularity"/>
+ </require>
+ <require comment="Command pool commands">
+ <command name="vkCreateCommandPool"/>
+ <command name="vkDestroyCommandPool"/>
+ <command name="vkResetCommandPool"/>
+ </require>
+ <require comment="Command buffer commands">
+ <command name="vkAllocateCommandBuffers"/>
+ <command name="vkFreeCommandBuffers"/>
+ <command name="vkBeginCommandBuffer"/>
+ <command name="vkEndCommandBuffer"/>
+ <command name="vkResetCommandBuffer"/>
+ </require>
+ <require comment="Command buffer building commands">
+ <command name="vkCmdBindPipeline"/>
+ <command name="vkCmdSetViewport"/>
+ <command name="vkCmdSetScissor"/>
+ <command name="vkCmdSetLineWidth"/>
+ <command name="vkCmdSetDepthBias"/>
+ <command name="vkCmdSetBlendConstants"/>
+ <command name="vkCmdSetDepthBounds"/>
+ <command name="vkCmdSetStencilCompareMask"/>
+ <command name="vkCmdSetStencilWriteMask"/>
+ <command name="vkCmdSetStencilReference"/>
+ <command name="vkCmdBindDescriptorSets"/>
+ <command name="vkCmdBindIndexBuffer"/>
+ <command name="vkCmdBindVertexBuffers"/>
+ <command name="vkCmdDraw"/>
+ <command name="vkCmdDrawIndexed"/>
+ <command name="vkCmdDrawIndirect"/>
+ <command name="vkCmdDrawIndexedIndirect"/>
+ <command name="vkCmdDispatch"/>
+ <command name="vkCmdDispatchIndirect"/>
+ <command name="vkCmdCopyBuffer"/>
+ <command name="vkCmdCopyImage"/>
+ <command name="vkCmdBlitImage"/>
+ <command name="vkCmdCopyBufferToImage"/>
+ <command name="vkCmdCopyImageToBuffer"/>
+ <command name="vkCmdUpdateBuffer"/>
+ <command name="vkCmdFillBuffer"/>
+ <command name="vkCmdClearColorImage"/>
+ <command name="vkCmdClearDepthStencilImage"/>
+ <command name="vkCmdClearAttachments"/>
+ <command name="vkCmdResolveImage"/>
+ <command name="vkCmdSetEvent"/>
+ <command name="vkCmdResetEvent"/>
+ <command name="vkCmdWaitEvents"/>
+ <command name="vkCmdPipelineBarrier"/>
+ <command name="vkCmdBeginQuery"/>
+ <command name="vkCmdEndQuery"/>
+ <command name="vkCmdResetQueryPool"/>
+ <command name="vkCmdWriteTimestamp"/>
+ <command name="vkCmdCopyQueryPoolResults"/>
+ <command name="vkCmdPushConstants"/>
+ <command name="vkCmdBeginRenderPass"/>
+ <command name="vkCmdNextSubpass"/>
+ <command name="vkCmdEndRenderPass"/>
+ <command name="vkCmdExecuteCommands"/>
+ </require>
+ <require comment="Types not directly used by the API. Include e.g. structs that are not parameter types of commands, but still defined by the API.">
+ <type name="VkBufferMemoryBarrier"/>
+ <type name="VkDispatchIndirectCommand"/>
+ <type name="VkDrawIndexedIndirectCommand"/>
+ <type name="VkDrawIndirectCommand"/>
+ <type name="VkImageMemoryBarrier"/>
+ <type name="VkMemoryBarrier"/>
+ <type name="VkObjectType"/>
+ </require>
+ </feature>
+ <feature api="vulkan" name="VK_VERSION_1_1" number="1.1" comment="Vulkan 1.1 core API interface definitions.">
+ <require>
+ <type name="VK_API_VERSION_1_1"/>
+ </require>
+ <require comment="Device Initialization">
+ <command name="vkEnumerateInstanceVersion"/>
+ </require>
+ <require comment="Promoted from VK_KHR_relaxed_block_layout, which has no API"/>
+ <require comment="Promoted from VK_KHR_storage_buffer_storage_class, which has no API"/>
+ <require comment="Originally based on VK_KHR_subgroup (extension 94), but the actual enum block used was, incorrectly, that of extension 95">
+ <enum extends="VkStructureType" extnumber="95" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES"/>
+ <type name="VkPhysicalDeviceSubgroupProperties"/>
+ <type name="VkSubgroupFeatureFlags"/>
+ <type name="VkSubgroupFeatureFlagBits"/>
+ </require>
+ <require comment="Promoted from VK_KHR_bind_memory2">
+ <command name="vkBindBufferMemory2"/>
+ <command name="vkBindImageMemory2"/>
+ <enum extends="VkStructureType" extnumber="158" offset="0" name="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO"/>
+ <enum extends="VkStructureType" extnumber="158" offset="1" name="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO"/>
+ <enum bitpos="10" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_ALIAS_BIT"/>
+ <type name="VkBindBufferMemoryInfo"/>
+ <type name="VkBindImageMemoryInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_16bit_storage">
+ <enum extends="VkStructureType" extnumber="84" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES"/>
+ <type name="VkPhysicalDevice16BitStorageFeatures"/>
+ </require>
+ <require comment="Promoted from VK_KHR_dedicated_allocation">
+ <enum extends="VkStructureType" extnumber="128" offset="0" name="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS"/>
+ <enum extends="VkStructureType" extnumber="128" offset="1" name="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO"/>
+ <type name="VkMemoryDedicatedRequirements"/>
+ <type name="VkMemoryDedicatedAllocateInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_device_group">
+ <enum extends="VkStructureType" extnumber="61" offset="0" name="VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO"/>
+ <comment>offset 1 reserved for the old VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO_KHX enum</comment>
+ <comment>offset 2 reserved for the old VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO_KHX enum</comment>
+ <enum extends="VkStructureType" extnumber="61" offset="3" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO"/>
+ <enum extends="VkStructureType" extnumber="61" offset="4" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO"/>
+ <enum extends="VkStructureType" extnumber="61" offset="5" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO"/>
+ <enum extends="VkStructureType" extnumber="61" offset="6" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO"/>
+ <type name="VkPeerMemoryFeatureFlags"/>
+ <type name="VkPeerMemoryFeatureFlagBits"/>
+ <type name="VkMemoryAllocateFlags"/>
+ <type name="VkMemoryAllocateFlagBits"/>
+ <type name="VkMemoryAllocateFlagsInfo"/>
+ <type name="VkDeviceGroupRenderPassBeginInfo"/>
+ <type name="VkDeviceGroupCommandBufferBeginInfo"/>
+ <type name="VkDeviceGroupSubmitInfo"/>
+ <type name="VkDeviceGroupBindSparseInfo"/>
+ <command name="vkGetDeviceGroupPeerMemoryFeatures"/>
+ <command name="vkCmdSetDeviceMask"/>
+ <command name="vkCmdDispatchBase"/>
+ <enum bitpos="3" extends="VkPipelineCreateFlagBits" name="VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT"/>
+ <enum bitpos="4" extends="VkPipelineCreateFlagBits" name="VK_PIPELINE_CREATE_DISPATCH_BASE"/>
+ <enum bitpos="2" extends="VkDependencyFlagBits" name="VK_DEPENDENCY_DEVICE_GROUP_BIT" comment="Dependency is across devices"/>
+ </require>
+ <require comment="Promoted from VK_KHR_device_group + VK_KHR_bind_memory2">
+ <enum extends="VkStructureType" extnumber="61" offset="13" name="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO"/>
+ <enum extends="VkStructureType" extnumber="61" offset="14" name="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO"/>
+ <type name="VkBindBufferMemoryDeviceGroupInfo"/>
+ <type name="VkBindImageMemoryDeviceGroupInfo"/>
+ <enum bitpos="6" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT" comment="Allows using VkBindImageMemoryDeviceGroupInfo::pSplitInstanceBindRegions when binding memory to the image"/>
+ </require>
+ <require comment="Promoted from VK_KHR_device_group_creation">
+ <enum extends="VkStructureType" extnumber="71" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES"/>
+ <enum extends="VkStructureType" extnumber="71" offset="1" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO"/>
+ <enum name="VK_MAX_DEVICE_GROUP_SIZE"/>
+ <type name="VkPhysicalDeviceGroupProperties"/>
+ <type name="VkDeviceGroupDeviceCreateInfo"/>
+ <command name="vkEnumeratePhysicalDeviceGroups"/>
+ <enum bitpos="1" extends="VkMemoryHeapFlagBits" name="VK_MEMORY_HEAP_MULTI_INSTANCE_BIT" comment="If set, heap allocations allocate multiple instances by default"/>
+ </require>
+ <require comment="Promoted from VK_KHR_get_memory_requirements2">
+ <enum extends="VkStructureType" extnumber="147" offset="0" name="VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2"/>
+ <enum extends="VkStructureType" extnumber="147" offset="1" name="VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2"/>
+ <enum extends="VkStructureType" extnumber="147" offset="2" name="VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2"/>
+ <enum extends="VkStructureType" extnumber="147" offset="3" name="VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2"/>
+ <enum extends="VkStructureType" extnumber="147" offset="4" name="VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2"/>
+ <type name="VkBufferMemoryRequirementsInfo2"/>
+ <type name="VkImageMemoryRequirementsInfo2"/>
+ <type name="VkImageSparseMemoryRequirementsInfo2"/>
+ <type name="VkMemoryRequirements2"/>
+ <type name="VkSparseImageMemoryRequirements2"/>
+ <command name="vkGetImageMemoryRequirements2"/>
+ <command name="vkGetBufferMemoryRequirements2"/>
+ <command name="vkGetImageSparseMemoryRequirements2"/>
+ </require>
+ <require comment="Promoted from VK_KHR_get_physical_device_properties2">
+ <enum extends="VkStructureType" extnumber="60" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="1" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="2" name="VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="3" name="VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="4" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="5" name="VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="6" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="7" name="VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2"/>
+ <enum extends="VkStructureType" extnumber="60" offset="8" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2"/>
+ <type name="VkPhysicalDeviceFeatures2"/>
+ <type name="VkPhysicalDeviceProperties2"/>
+ <type name="VkFormatProperties2"/>
+ <type name="VkImageFormatProperties2"/>
+ <type name="VkPhysicalDeviceImageFormatInfo2"/>
+ <type name="VkQueueFamilyProperties2"/>
+ <type name="VkPhysicalDeviceMemoryProperties2"/>
+ <type name="VkSparseImageFormatProperties2"/>
+ <type name="VkPhysicalDeviceSparseImageFormatInfo2"/>
+ <command name="vkGetPhysicalDeviceFeatures2"/>
+ <command name="vkGetPhysicalDeviceProperties2"/>
+ <command name="vkGetPhysicalDeviceFormatProperties2"/>
+ <command name="vkGetPhysicalDeviceImageFormatProperties2"/>
+ <command name="vkGetPhysicalDeviceQueueFamilyProperties2"/>
+ <command name="vkGetPhysicalDeviceMemoryProperties2"/>
+ <command name="vkGetPhysicalDeviceSparseImageFormatProperties2"/>
+ </require>
+ <require comment="Promoted from VK_KHR_maintenance1">
+ <enum extends="VkResult" extnumber="70" offset="0" dir="-" name="VK_ERROR_OUT_OF_POOL_MEMORY"/>
+ <enum bitpos="14" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_TRANSFER_SRC_BIT" comment="Format can be used as the source image of image transfer commands"/>
+ <enum bitpos="15" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_TRANSFER_DST_BIT" comment="Format can be used as the destination image of image transfer commands"/>
+ <enum bitpos="5" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT" comment="The 3D image can be viewed as a 2D or 2D array image"/>
+ <command name="vkTrimCommandPool"/>
+ <comment>Additional dependent types / tokens extending enumerants, not explicitly mentioned</comment>
+ <type name="VkCommandPoolTrimFlags"/>
+ </require>
+ <require comment="Promoted from VK_KHR_maintenance2">
+ <enum bitpos="7" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT"/>
+ <enum bitpos="8" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_EXTENDED_USAGE_BIT"/>
+ <enum extends="VkStructureType" extnumber="118" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES"/>
+ <enum extends="VkStructureType" extnumber="118" offset="1" name="VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO"/>
+ <enum extends="VkStructureType" extnumber="118" offset="2" name="VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO"/>
+ <enum extends="VkStructureType" extnumber="118" offset="3" name="VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO"/>
+ <enum extends="VkImageLayout" extnumber="118" offset="0" name="VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL"/>
+ <enum extends="VkImageLayout" extnumber="118" offset="1" name="VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL"/>
+ <type name="VkPhysicalDevicePointClippingProperties"/>
+ <type name="VkPointClippingBehavior"/>
+ <type name="VkRenderPassInputAttachmentAspectCreateInfo"/>
+ <type name="VkInputAttachmentAspectReference"/>
+ <type name="VkImageViewUsageCreateInfo"/>
+ <type name="VkTessellationDomainOrigin"/>
+ <type name="VkPipelineTessellationDomainOriginStateCreateInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_multiview">
+ <enum extends="VkStructureType" extnumber="54" offset="0" name="VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO"/>
+ <enum extends="VkStructureType" extnumber="54" offset="1" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES"/>
+ <enum extends="VkStructureType" extnumber="54" offset="2" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES"/>
+ <enum bitpos="1" extends="VkDependencyFlagBits" name="VK_DEPENDENCY_VIEW_LOCAL_BIT"/>
+ <type name="VkRenderPassMultiviewCreateInfo"/>
+ <type name="VkPhysicalDeviceMultiviewFeatures"/>
+ <type name="VkPhysicalDeviceMultiviewProperties"/>
+ </require>
+ <require comment="Promoted from VK_KHR_variable_pointers">
+ <enum extends="VkStructureType" extnumber="121" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES"/>
+ <type name="VkPhysicalDeviceVariablePointerFeatures"/>
+ </require>
+ <require comment="Originally based on VK_KHR_protected_memory (extension 146), which was never published; thus the mystifying large value= numbers below. These are not aliased since they weren't actually promoted from an extension.">
+ <enum extends="VkStructureType" extnumber="146" offset="0" name="VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO"/>
+ <enum extends="VkStructureType" extnumber="146" offset="1" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES"/>
+ <enum extends="VkStructureType" extnumber="146" offset="2" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES"/>
+ <enum extends="VkStructureType" extnumber="146" offset="3" name="VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2"/>
+ <enum bitpos="4" extends="VkQueueFlagBits" name="VK_QUEUE_PROTECTED_BIT" comment="Queues may support protected operations"/>
+ <enum bitpos="0" extends="VkDeviceQueueCreateFlagBits" name="VK_DEVICE_QUEUE_CREATE_PROTECTED_BIT" comment="Queue is a protected-capable device queue"/>
+ <enum bitpos="5" extends="VkMemoryPropertyFlagBits" name="VK_MEMORY_PROPERTY_PROTECTED_BIT" comment="Memory is protected"/>
+ <enum bitpos="3" extends="VkBufferCreateFlagBits" name="VK_BUFFER_CREATE_PROTECTED_BIT" comment="Buffer requires protected memory"/>
+ <enum bitpos="11" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_PROTECTED_BIT" comment="Image requires protected memory"/>
+ <enum bitpos="2" extends="VkCommandPoolCreateFlagBits" name="VK_COMMAND_POOL_CREATE_PROTECTED_BIT" comment="Command buffers allocated from pool are protected command buffers"/>
+ <type name="VkPhysicalDeviceProtectedMemoryFeatures"/>
+ <type name="VkPhysicalDeviceProtectedMemoryProperties"/>
+ <type name="VkDeviceQueueInfo2"/>
+ <type name="VkProtectedSubmitInfo"/>
+ <command name="vkGetDeviceQueue2"/>
+ </require>
+ <require comment="Promoted from VK_KHR_sampler_ycbcr_conversion">
+ <enum extends="VkStructureType" extnumber="157" offset="0" name="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO"/>
+ <enum extends="VkStructureType" extnumber="157" offset="1" name="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO"/>
+ <enum extends="VkStructureType" extnumber="157" offset="2" name="VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO"/>
+ <enum extends="VkStructureType" extnumber="157" offset="3" name="VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO"/>
+ <enum extends="VkStructureType" extnumber="157" offset="4" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES"/>
+ <enum extends="VkStructureType" extnumber="157" offset="5" name="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES"/>
+ <enum extends="VkObjectType" extnumber="157" offset="0" name="VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION"/>
+ <enum extends="VkFormat" extnumber="157" offset="0" name="VK_FORMAT_G8B8G8R8_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="1" name="VK_FORMAT_B8G8R8G8_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="2" name="VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="3" name="VK_FORMAT_G8_B8R8_2PLANE_420_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="4" name="VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="5" name="VK_FORMAT_G8_B8R8_2PLANE_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="6" name="VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="7" name="VK_FORMAT_R10X6_UNORM_PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="8" name="VK_FORMAT_R10X6G10X6_UNORM_2PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="9" name="VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="10" name="VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="11" name="VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="12" name="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="13" name="VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="14" name="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="15" name="VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="16" name="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="17" name="VK_FORMAT_R12X4_UNORM_PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="18" name="VK_FORMAT_R12X4G12X4_UNORM_2PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="19" name="VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="20" name="VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="21" name="VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="22" name="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="23" name="VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="24" name="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="25" name="VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="26" name="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16"/>
+ <enum extends="VkFormat" extnumber="157" offset="27" name="VK_FORMAT_G16B16G16R16_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="28" name="VK_FORMAT_B16G16R16G16_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="29" name="VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="30" name="VK_FORMAT_G16_B16R16_2PLANE_420_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="31" name="VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="32" name="VK_FORMAT_G16_B16R16_2PLANE_422_UNORM"/>
+ <enum extends="VkFormat" extnumber="157" offset="33" name="VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM"/>
+ <enum bitpos="4" extends="VkImageAspectFlagBits" name="VK_IMAGE_ASPECT_PLANE_0_BIT"/>
+ <enum bitpos="5" extends="VkImageAspectFlagBits" name="VK_IMAGE_ASPECT_PLANE_1_BIT"/>
+ <enum bitpos="6" extends="VkImageAspectFlagBits" name="VK_IMAGE_ASPECT_PLANE_2_BIT"/>
+ <enum bitpos="9" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_DISJOINT_BIT"/>
+ <enum bitpos="17" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT" comment="Format can have midpoint rather than cosited chroma samples"/>
+ <enum bitpos="18" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT" comment="Format can be used with linear filtering whilst color conversion is enabled"/>
+ <enum bitpos="19" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT" comment="Format can have different chroma, min and mag filters"/>
+ <enum bitpos="20" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT"/>
+ <enum bitpos="21" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT"/>
+ <enum bitpos="22" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_DISJOINT_BIT" comment="Format supports disjoint planes"/>
+ <enum bitpos="23" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT" comment="Format can have cosited rather than midpoint chroma samples"/>
+ <type name="VkSamplerYcbcrConversionCreateInfo"/>
+ <type name="VkSamplerYcbcrConversionInfo"/>
+ <type name="VkBindImagePlaneMemoryInfo"/>
+ <type name="VkImagePlaneMemoryRequirementsInfo"/>
+ <type name="VkPhysicalDeviceSamplerYcbcrConversionFeatures"/>
+ <type name="VkSamplerYcbcrConversionImageFormatProperties"/>
+ <command name="vkCreateSamplerYcbcrConversion"/>
+ <command name="vkDestroySamplerYcbcrConversion"/>
+ <comment>Additional dependent types / tokens extending enumerants, not explicitly mentioned</comment>
+ <type name="VkSamplerYcbcrConversion"/>
+ <type name="VkSamplerYcbcrModelConversion"/>
+ <type name="VkSamplerYcbcrRange"/>
+ <type name="VkChromaLocation"/>
+ </require>
+ <require comment="Promoted from VK_KHR_descriptor_update_template">
+ <enum extends="VkStructureType" extnumber="86" offset="0" name="VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO"/>
+ <enum extends="VkObjectType" extnumber="86" offset="0" name="VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE"/>
+ <command name="vkCreateDescriptorUpdateTemplate"/>
+ <command name="vkDestroyDescriptorUpdateTemplate"/>
+ <command name="vkUpdateDescriptorSetWithTemplate"/>
+ <type name="VkDescriptorUpdateTemplate"/>
+ <type name="VkDescriptorUpdateTemplateCreateFlags"/>
+ <type name="VkDescriptorUpdateTemplateType"/>
+ <type name="VkDescriptorUpdateTemplateEntry"/>
+ <type name="VkDescriptorUpdateTemplateCreateInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_external_memory_capabilities">
+ <enum extends="VkStructureType" extnumber="72" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO"/>
+ <enum extends="VkStructureType" extnumber="72" offset="1" name="VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES"/>
+ <enum extends="VkStructureType" extnumber="72" offset="2" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO"/>
+ <enum extends="VkStructureType" extnumber="72" offset="3" name="VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES"/>
+ <enum extends="VkStructureType" extnumber="72" offset="4" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES"/>
+ <enum name="VK_LUID_SIZE"/>
+ <type name="VkExternalMemoryHandleTypeFlags"/>
+ <type name="VkExternalMemoryHandleTypeFlagBits"/>
+ <type name="VkExternalMemoryFeatureFlags"/>
+ <type name="VkExternalMemoryFeatureFlagBits"/>
+ <type name="VkExternalMemoryProperties"/>
+ <type name="VkPhysicalDeviceExternalImageFormatInfo"/>
+ <type name="VkExternalImageFormatProperties"/>
+ <type name="VkPhysicalDeviceExternalBufferInfo"/>
+ <type name="VkExternalBufferProperties"/>
+ <type name="VkPhysicalDeviceIDProperties"/>
+ <command name="vkGetPhysicalDeviceExternalBufferProperties"/>
+ </require>
+ <require comment="Promoted from VK_KHR_external_memory">
+ <enum extends="VkStructureType" extnumber="73" offset="0" name="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO"/>
+ <enum extends="VkStructureType" extnumber="73" offset="1" name="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO"/>
+ <enum extends="VkStructureType" extnumber="73" offset="2" name="VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO"/>
+ <enum extends="VkResult" extnumber="73" offset="3" dir="-" name="VK_ERROR_INVALID_EXTERNAL_HANDLE"/>
+ <enum name="VK_QUEUE_FAMILY_EXTERNAL"/>
+ <type name="VkExternalMemoryImageCreateInfo"/>
+ <type name="VkExternalMemoryBufferCreateInfo"/>
+ <type name="VkExportMemoryAllocateInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_external_fence_capabilities">
+ <enum extends="VkStructureType" extnumber="113" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO"/>
+ <enum extends="VkStructureType" extnumber="113" offset="1" name="VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES"/>
+ <type name="VkExternalFenceHandleTypeFlags"/>
+ <type name="VkExternalFenceHandleTypeFlagBits"/>
+ <type name="VkExternalFenceFeatureFlags"/>
+ <type name="VkExternalFenceFeatureFlagBits"/>
+ <type name="VkPhysicalDeviceExternalFenceInfo"/>
+ <type name="VkExternalFenceProperties"/>
+ <command name="vkGetPhysicalDeviceExternalFenceProperties"/>
+ </require>
+ <require comment="Promoted from VK_KHR_external_fence">
+ <enum extends="VkStructureType" extnumber="114" offset="0" name="VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO"/>
+ <type name="VkFenceImportFlags"/>
+ <type name="VkFenceImportFlagBits"/>
+ <type name="VkExportFenceCreateInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_external_semaphore">
+ <enum extends="VkStructureType" extnumber="78" offset="0" name="VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO"/>
+ <type name="VkSemaphoreImportFlags"/>
+ <type name="VkSemaphoreImportFlagBits"/>
+ <type name="VkExportSemaphoreCreateInfo"/>
+ </require>
+ <require comment="Promoted from VK_KHR_external_semaphore_capabilities">
+ <enum extends="VkStructureType" extnumber="77" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO"/>
+ <enum extends="VkStructureType" extnumber="77" offset="1" name="VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES"/>
+ <type name="VkExternalSemaphoreHandleTypeFlags"/>
+ <type name="VkExternalSemaphoreHandleTypeFlagBits"/>
+ <type name="VkExternalSemaphoreFeatureFlags"/>
+ <type name="VkExternalSemaphoreFeatureFlagBits"/>
+ <type name="VkPhysicalDeviceExternalSemaphoreInfo"/>
+ <type name="VkExternalSemaphoreProperties"/>
+ <command name="vkGetPhysicalDeviceExternalSemaphoreProperties"/>
+ </require>
+ <require comment="Promoted from VK_KHR_maintenance3">
+ <enum extends="VkStructureType" extnumber="169" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES"/>
+ <enum extends="VkStructureType" extnumber="169" offset="1" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT"/>
+ <type name="VkPhysicalDeviceMaintenance3Properties"/>
+ <type name="VkDescriptorSetLayoutSupport"/>
+ <command name="vkGetDescriptorSetLayoutSupport"/>
+ </require>
+ <require comment="Promoted from VK_KHR_shader_draw_parameters, with a feature support query added">
+ <enum extends="VkStructureType" extnumber="64" offset="0" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES"/>
+ <type name="VkPhysicalDeviceShaderDrawParameterFeatures"/>
+ </require>
+ </feature>
+
+
+ <extensions comment="Vulkan extension interface definitions">
+ <extension name="VK_KHR_surface" number="1" type="instance" author="KHR" contact="James Jones @cubanismo,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="25" name="VK_KHR_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_surface"" name="VK_KHR_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkResult" dir="-" name="VK_ERROR_SURFACE_LOST_KHR"/>
+ <enum offset="1" extends="VkResult" dir="-" name="VK_ERROR_NATIVE_WINDOW_IN_USE_KHR"/>
+ <enum value="VK_COLOR_SPACE_SRGB_NONLINEAR_KHR" name="VK_COLORSPACE_SRGB_NONLINEAR_KHR"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_SURFACE_KHR" comment="VkSurfaceKHR"/>
+ <command name="vkDestroySurfaceKHR"/>
+ <command name="vkGetPhysicalDeviceSurfaceSupportKHR"/>
+ <command name="vkGetPhysicalDeviceSurfaceCapabilitiesKHR"/>
+ <command name="vkGetPhysicalDeviceSurfaceFormatsKHR"/>
+ <command name="vkGetPhysicalDeviceSurfacePresentModesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_swapchain" number="2" type="device" requires="VK_KHR_surface" author="KHR" contact="James Jones @cubanismo,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="70" name="VK_KHR_SWAPCHAIN_SPEC_VERSION"/>
+ <enum value=""VK_KHR_swapchain"" name="VK_KHR_SWAPCHAIN_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PRESENT_INFO_KHR"/>
+ <enum offset="2" extends="VkImageLayout" name="VK_IMAGE_LAYOUT_PRESENT_SRC_KHR"/>
+ <enum offset="3" extends="VkResult" name="VK_SUBOPTIMAL_KHR"/>
+ <enum offset="4" extends="VkResult" dir="-" name="VK_ERROR_OUT_OF_DATE_KHR"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_SWAPCHAIN_KHR" comment="VkSwapchainKHR"/>
+ <command name="vkCreateSwapchainKHR"/>
+ <command name="vkDestroySwapchainKHR"/>
+ <command name="vkGetSwapchainImagesKHR"/>
+ <command name="vkAcquireNextImageKHR"/>
+ <command name="vkQueuePresentKHR"/>
+ </require>
+ <require feature="VK_VERSION_1_1">
+ <comment>This duplicates definitions in VK_KHR_device_group below</comment>
+ <enum extends="VkStructureType" extnumber="61" offset="7" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR"/>
+ <enum extends="VkStructureType" extnumber="61" offset="8" name="VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR"/>
+ <enum extends="VkStructureType" extnumber="61" offset="9" name="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR"/>
+ <enum extends="VkStructureType" extnumber="61" offset="10" name="VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR"/>
+ <enum extends="VkStructureType" extnumber="61" offset="11" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR"/>
+ <enum extends="VkStructureType" extnumber="61" offset="12" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR"/>
+ <enum bitpos="0" extends="VkSwapchainCreateFlagBitsKHR" name="VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR" comment="Allow images with VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT"/>
+ <type name="VkImageSwapchainCreateInfoKHR"/>
+ <type name="VkBindImageMemorySwapchainInfoKHR"/>
+ <type name="VkAcquireNextImageInfoKHR"/>
+ <type name="VkDeviceGroupPresentModeFlagBitsKHR"/>
+ <type name="VkDeviceGroupPresentModeFlagsKHR"/>
+ <type name="VkDeviceGroupPresentCapabilitiesKHR"/>
+ <type name="VkDeviceGroupPresentInfoKHR"/>
+ <type name="VkDeviceGroupSwapchainCreateInfoKHR"/>
+ <command name="vkGetDeviceGroupPresentCapabilitiesKHR"/>
+ <command name="vkGetDeviceGroupSurfacePresentModesKHR"/>
+ <command name="vkGetPhysicalDevicePresentRectanglesKHR"/>
+ <command name="vkAcquireNextImage2KHR"/>
+ <enum bitpos="1" extends="VkSwapchainCreateFlagBitsKHR" name="VK_SWAPCHAIN_CREATE_PROTECTED_BIT_KHR" comment="Swapchain is protected"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_display" number="3" type="instance" requires="VK_KHR_surface" author="KHR" contact="James Jones @cubanismo,Norbert Nopper @FslNopper" supported="vulkan">
+ <require>
+ <enum value="21" name="VK_KHR_DISPLAY_SPEC_VERSION"/>
+ <enum value=""VK_KHR_display"" name="VK_KHR_DISPLAY_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_DISPLAY_KHR" comment="VkDisplayKHR"/>
+ <enum offset="1" extends="VkObjectType" name="VK_OBJECT_TYPE_DISPLAY_MODE_KHR" comment="VkDisplayModeKHR"/>
+ <type name="VkDisplayPlaneAlphaFlagsKHR"/>
+ <type name="VkDisplayPlaneAlphaFlagBitsKHR"/>
+ <type name="VkDisplayPropertiesKHR"/>
+ <type name="VkDisplayModeParametersKHR"/>
+ <type name="VkDisplayModePropertiesKHR"/>
+ <type name="VkDisplayModeCreateInfoKHR"/>
+ <type name="VkDisplayPlaneCapabilitiesKHR"/>
+ <type name="VkDisplayPlanePropertiesKHR"/>
+ <type name="VkDisplaySurfaceCreateInfoKHR"/>
+ <command name="vkGetPhysicalDeviceDisplayPropertiesKHR"/>
+ <command name="vkGetPhysicalDeviceDisplayPlanePropertiesKHR"/>
+ <command name="vkGetDisplayPlaneSupportedDisplaysKHR"/>
+ <command name="vkGetDisplayModePropertiesKHR"/>
+ <command name="vkCreateDisplayModeKHR"/>
+ <command name="vkGetDisplayPlaneCapabilitiesKHR"/>
+ <command name="vkCreateDisplayPlaneSurfaceKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_display_swapchain" number="4" type="device" requires="VK_KHR_swapchain,VK_KHR_display" author="KHR" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="9" name="VK_KHR_DISPLAY_SWAPCHAIN_SPEC_VERSION"/>
+ <enum value=""VK_KHR_display_swapchain"" name="VK_KHR_DISPLAY_SWAPCHAIN_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR"/>
+ <enum offset="1" extends="VkResult" dir="-" name="VK_ERROR_INCOMPATIBLE_DISPLAY_KHR"/>
+ <type name="VkDisplayPresentInfoKHR"/>
+ <command name="vkCreateSharedSwapchainsKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_xlib_surface" number="5" type="instance" requires="VK_KHR_surface" platform="xlib" author="KHR" contact="Jesse Hall @jessehall,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="6" name="VK_KHR_XLIB_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_xlib_surface"" name="VK_KHR_XLIB_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR"/>
+ <type name="VkXlibSurfaceCreateFlagsKHR"/>
+ <type name="VkXlibSurfaceCreateInfoKHR"/>
+ <command name="vkCreateXlibSurfaceKHR"/>
+ <command name="vkGetPhysicalDeviceXlibPresentationSupportKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_xcb_surface" number="6" type="instance" requires="VK_KHR_surface" platform="xcb" author="KHR" contact="Jesse Hall @jessehall,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="6" name="VK_KHR_XCB_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_xcb_surface"" name="VK_KHR_XCB_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_XCB_SURFACE_CREATE_INFO_KHR"/>
+ <type name="VkXcbSurfaceCreateFlagsKHR"/>
+ <type name="VkXcbSurfaceCreateInfoKHR"/>
+ <command name="vkCreateXcbSurfaceKHR"/>
+ <command name="vkGetPhysicalDeviceXcbPresentationSupportKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_wayland_surface" number="7" type="instance" requires="VK_KHR_surface" platform="wayland" author="KHR" contact="Jesse Hall @jessehall,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="6" name="VK_KHR_WAYLAND_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_wayland_surface"" name="VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR"/>
+ <type name="VkWaylandSurfaceCreateFlagsKHR"/>
+ <type name="VkWaylandSurfaceCreateInfoKHR"/>
+ <command name="vkCreateWaylandSurfaceKHR"/>
+ <command name="vkGetPhysicalDeviceWaylandPresentationSupportKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_mir_surface" number="8" type="instance" requires="VK_KHR_surface" platform="mir" author="KHR" contact="Jesse Hall @jessehall,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="4" name="VK_KHR_MIR_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_mir_surface"" name="VK_KHR_MIR_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MIR_SURFACE_CREATE_INFO_KHR"/>
+ <type name="VkMirSurfaceCreateFlagsKHR"/>
+ <type name="VkMirSurfaceCreateInfoKHR"/>
+ <command name="vkCreateMirSurfaceKHR"/>
+ <command name="vkGetPhysicalDeviceMirPresentationSupportKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_android_surface" number="9" type="instance" requires="VK_KHR_surface" platform="android" author="KHR" contact="Jesse Hall @jessehall" supported="vulkan">
+ <require>
+ <enum value="6" name="VK_KHR_ANDROID_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_android_surface"" name="VK_KHR_ANDROID_SURFACE_EXTENSION_NAME"/>
+ <type name="ANativeWindow"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_ANDROID_SURFACE_CREATE_INFO_KHR"/>
+ <type name="VkAndroidSurfaceCreateFlagsKHR"/>
+ <type name="VkAndroidSurfaceCreateInfoKHR"/>
+ <command name="vkCreateAndroidSurfaceKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_win32_surface" number="10" type="instance" requires="VK_KHR_surface" platform="win32" author="KHR" contact="Jesse Hall @jessehall,Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="6" name="VK_KHR_WIN32_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_win32_surface"" name="VK_KHR_WIN32_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR"/>
+ <type name="VkWin32SurfaceCreateFlagsKHR"/>
+ <type name="VkWin32SurfaceCreateInfoKHR"/>
+ <command name="vkCreateWin32SurfaceKHR"/>
+ <command name="vkGetPhysicalDeviceWin32PresentationSupportKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_ANDROID_native_buffer" number="11" type="device" author="ANDROID" platform="android" contact="Jesse Hall @jessehall" supported="disabled">
+ <require>
+ <enum value="5" name="VK_ANDROID_NATIVE_BUFFER_SPEC_VERSION"/>
+ <enum value="11" name="VK_ANDROID_NATIVE_BUFFER_NUMBER"/>
+ <enum value=""VK_ANDROID_native_buffer"" name="VK_ANDROID_NATIVE_BUFFER_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_NATIVE_BUFFER_ANDROID"/>
+ <type name="VkNativeBufferANDROID"/>
+ <command name="vkGetSwapchainGrallocUsageANDROID"/>
+ <command name="vkAcquireImageANDROID"/>
+ <command name="vkQueueSignalReleaseImageANDROID"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_debug_report" number="12" type="instance" author="GOOGLE" contact="Courtney Goeltzenleuchter @courtney" supported="vulkan">
+ <require>
+ <enum value="9" name="VK_EXT_DEBUG_REPORT_SPEC_VERSION"/>
+ <enum value=""VK_EXT_debug_report"" name="VK_EXT_DEBUG_REPORT_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT"/>
+ <enum offset="1" extends="VkResult" dir="-" name="VK_ERROR_VALIDATION_FAILED_EXT"/>
+ <enum value="VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT" name="VK_STRUCTURE_TYPE_DEBUG_REPORT_CREATE_INFO_EXT"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT" comment="VkDebugReportCallbackEXT"/>
+ <enum value="VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT_EXT" name="VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPORT_EXT"/>
+ <type name="VkDebugReportObjectTypeEXT"/>
+ <type name="VkDebugReportCallbackCreateInfoEXT"/>
+ <command name="vkCreateDebugReportCallbackEXT"/>
+ <command name="vkDestroyDebugReportCallbackEXT"/>
+ <command name="vkDebugReportMessageEXT"/>
+ </require>
+ <require feature="VK_VERSION_1_1">
+ <comment>This duplicates definitions in other extensions, below</comment>
+ <enum extends="VkDebugReportObjectTypeEXT" extnumber="157" offset="0" name="VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT"/>
+ <enum extends="VkDebugReportObjectTypeEXT" extnumber="86" offset="0" name="VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_glsl_shader" number="13" type="device" author="NV" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_GLSL_SHADER_SPEC_VERSION"/>
+ <enum value=""VK_NV_glsl_shader"" name="VK_NV_GLSL_SHADER_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkResult" dir="-" name="VK_ERROR_INVALID_SHADER_NV"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_depth_range_unrestricted" type="device" number="14" author="NV" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_DEPTH_RANGE_UNRESTRICTED_SPEC_VERSION"/>
+ <enum value=""VK_EXT_depth_range_unrestricted"" name="VK_EXT_DEPTH_RANGE_UNRESTRICTED_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_sampler_mirror_clamp_to_edge" type="device" number="15" author="KHR" contact="Tobias Hector @tobias" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_sampler_mirror_clamp_to_edge"" name="VK_KHR_SAMPLER_MIRROR_CLAMP_TO_EDGE_EXTENSION_NAME"/>
+ <enum value="4" extends="VkSamplerAddressMode" name="VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE" comment="Note that this defines what was previously a core enum, and so uses the 'value' attribute rather than 'offset', and does not have a suffix. This is a special case, and should not be repeated"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_filter_cubic" number="16" type="device" author="IMG" contact="Tobias Hector @tobias" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_IMG_FILTER_CUBIC_SPEC_VERSION"/>
+ <enum value=""VK_IMG_filter_cubic"" name="VK_IMG_FILTER_CUBIC_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkFilter" name="VK_FILTER_CUBIC_IMG"/>
+ <enum bitpos="13" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG" comment="Format can be filtered with VK_FILTER_CUBIC_IMG when being sampled"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_17" number="17" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_17_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_17"" name="VK_AMD_EXTENSION_17_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_18" number="18" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_18_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_18"" name="VK_AMD_EXTENSION_18_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_rasterization_order" number="19" type="device" author="AMD" contact="Daniel Rakos @aqnuep" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_RASTERIZATION_ORDER_SPEC_VERSION"/>
+ <enum value=""VK_AMD_rasterization_order"" name="VK_AMD_RASTERIZATION_ORDER_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD"/>
+ <type name="VkRasterizationOrderAMD"/>
+ <type name="VkPipelineRasterizationStateRasterizationOrderAMD"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_20" number="20" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_20_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_20"" name="VK_AMD_EXTENSION_20_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_trinary_minmax" number="21" type="device" author="AMD" contact="quentin.lin@amd.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_TRINARY_MINMAX_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_trinary_minmax"" name="VK_AMD_SHADER_TRINARY_MINMAX_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_explicit_vertex_parameter" number="22" type="device" author="AMD" contact="quentin.lin@amd.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_explicit_vertex_parameter"" name="VK_AMD_SHADER_EXPLICIT_VERTEX_PARAMETER_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_debug_marker" number="23" type="device" requires="VK_EXT_debug_report" author="Baldur Karlsson" contact="baldurk@baldurk.org" supported="vulkan">
+ <require>
+ <enum value="4" name="VK_EXT_DEBUG_MARKER_SPEC_VERSION"/>
+ <enum value=""VK_EXT_debug_marker"" name="VK_EXT_DEBUG_MARKER_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT"/>
+ <type name="VkDebugReportObjectTypeEXT"/>
+ <type name="VkDebugMarkerObjectNameInfoEXT"/>
+ <type name="VkDebugMarkerObjectTagInfoEXT"/>
+ <type name="VkDebugMarkerMarkerInfoEXT"/>
+ <command name="vkDebugMarkerSetObjectTagEXT"/>
+ <command name="vkDebugMarkerSetObjectNameEXT"/>
+ <command name="vkCmdDebugMarkerBeginEXT"/>
+ <command name="vkCmdDebugMarkerEndEXT"/>
+ <command name="vkCmdDebugMarkerInsertEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_24" number="24" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_24_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_24"" name="VK_AMD_EXTENSION_24_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_25" number="25" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_25_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_25"" name="VK_AMD_EXTENSION_25_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_gcn_shader" number="26" type="device" author="AMD" contact="dominik.witczak@amd.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_GCN_SHADER_SPEC_VERSION"/>
+ <enum value=""VK_AMD_gcn_shader"" name="VK_AMD_GCN_SHADER_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_dedicated_allocation" number="27" type="device" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_DEDICATED_ALLOCATION_SPEC_VERSION"/>
+ <enum value=""VK_NV_dedicated_allocation"" name="VK_NV_DEDICATED_ALLOCATION_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV"/>
+ <type name="VkDedicatedAllocationImageCreateInfoNV"/>
+ <type name="VkDedicatedAllocationBufferCreateInfoNV"/>
+ <type name="VkDedicatedAllocationMemoryAllocateInfoNV"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_28" number="28" author="NV" contact="Piers Daniell @pdaniell" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_28_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_28"" name="VK_EXT_EXTENSION_28_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_extension_29" number="29" author="NVX" contact="Jeff Juliano @jjuliano" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NVX_EXTENSION_29_SPEC_VERSION"/>
+ <enum value=""VK_NVX_extension_29"" name="VK_NVX_EXTENSION_29_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_extension_30" number="30" author="NVX" contact="Jeff Juliano @jjuliano" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NVX_EXTENSION_30_SPEC_VERSION"/>
+ <enum value=""VK_NVX_extension_30"" name="VK_NVX_EXTENSION_30_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_extension_31" number="31" author="NVX" contact="Jeff Juliano @jjuliano" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NVX_EXTENSION_31_SPEC_VERSION"/>
+ <enum value=""VK_NVX_extension_31"" name="VK_NVX_EXTENSION_31_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_32" number="32" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_32_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_32"" name="VK_AMD_EXTENSION_32_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_33" number="33" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_33_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_33"" name="VK_AMD_EXTENSION_33_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_draw_indirect_count" number="34" type="device" author="AMD" contact="Daniel Rakos @aqnuep" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_DRAW_INDIRECT_COUNT_SPEC_VERSION"/>
+ <enum value=""VK_AMD_draw_indirect_count"" name="VK_AMD_DRAW_INDIRECT_COUNT_EXTENSION_NAME"/>
+ <command name="vkCmdDrawIndirectCountAMD"/>
+ <command name="vkCmdDrawIndexedIndirectCountAMD"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_35" number="35" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_35_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_35"" name="VK_AMD_EXTENSION_35_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_negative_viewport_height" number="36" type="device" author="AMD" contact="Matthaeus G. Chajdas @anteru" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_SPEC_VERSION"/>
+ <enum value=""VK_AMD_negative_viewport_height"" name="VK_AMD_NEGATIVE_VIEWPORT_HEIGHT_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_gpu_shader_half_float" number="37" type="device" author="AMD" contact="Dominik Witczak @dominikwitczak_amd" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_GPU_SHADER_HALF_FLOAT_SPEC_VERSION"/>
+ <enum value=""VK_AMD_gpu_shader_half_float"" name="VK_AMD_GPU_SHADER_HALF_FLOAT_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_ballot" number="38" type="device" author="AMD" contact="Dominik Witczak @dominikwitczak_amd" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_BALLOT_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_ballot"" name="VK_AMD_SHADER_BALLOT_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_39" number="39" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_39_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_39"" name="VK_AMD_EXTENSION_39_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_40" number="40" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_40_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_40"" name="VK_AMD_EXTENSION_40_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_41" number="41" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_41_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_41"" name="VK_AMD_EXTENSION_41_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_texture_gather_bias_lod" number="42" author="AMD" contact="Rex Xu @amdrexu" supported="vulkan" type="device" requires="VK_KHR_get_physical_device_properties2">
+ <require>
+ <enum value="1" name="VK_AMD_TEXTURE_GATHER_BIAS_LOD_SPEC_VERSION"/>
+ <enum value=""VK_AMD_texture_gather_bias_lod"" name="VK_AMD_TEXTURE_GATHER_BIAS_LOD_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_TEXTURE_LOD_GATHER_FORMAT_PROPERTIES_AMD"/>
+ <type name="VkTextureLODGatherFormatPropertiesAMD"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_info" number="43" author="AMD" contact="Jaakko Konttinen @jaakko" supported="vulkan" type="device">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_INFO_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_info"" name="VK_AMD_SHADER_INFO_EXTENSION_NAME"/>
+ <type name="VkShaderInfoTypeAMD"/>
+ <type name="VkShaderResourceUsageAMD"/>
+ <type name="VkShaderStatisticsInfoAMD"/>
+ <command name="vkGetShaderInfoAMD"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_44" number="44" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_44_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_44"" name="VK_AMD_EXTENSION_44_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_45" number="45" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_45_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_45"" name="VK_AMD_EXTENSION_45_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_46" number="46" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_46_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_46"" name="VK_AMD_EXTENSION_46_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_image_load_store_lod" number="47" author="AMD" contact="Dominik Witczak @dominikwitczak_amd" supported="vulkan" type="device">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_image_load_store_lod"" name="VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_extension_48" number="48" author="NVX" contact="James Jones @cubanismo" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NVX_EXTENSION_48_SPEC_VERSION"/>
+ <enum value=""VK_NVX_extension_48"" name="VK_NVX_EXTENSION_48_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_49" number="49" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_49_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_49"" name="VK_GOOGLE_EXTENSION_49_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_50" number="50" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_50_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_50"" name="VK_GOOGLE_EXTENSION_50_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_extension_51" number="51" author="NVX" contact="James Jones @cubanismo" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NVX_EXTENSION_51_SPEC_VERSION"/>
+ <enum value=""VK_NVX_extension_51"" name="VK_NVX_EXTENSION_51_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_extension_52" number="52" author="NVX" contact="James Jones @cubanismo" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NVX_EXTENSION_52_SPEC_VERSION"/>
+ <enum value=""VK_NVX_extension_52"" name="VK_NVX_EXTENSION_52_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_53" number="53" author="NV" contact="Jeff Bolz @jbolz" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_53_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_53"" name="VK_NV_EXTENSION_53_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_multiview" number="54" type="device" author="KHR" requires="VK_KHR_get_physical_device_properties2" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_MULTIVIEW_SPEC_VERSION"/>
+ <enum value=""VK_KHR_multiview"" name="VK_KHR_MULTIVIEW_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES"/>
+ <enum extends="VkDependencyFlagBits" name="VK_DEPENDENCY_VIEW_LOCAL_BIT_KHR" alias="VK_DEPENDENCY_VIEW_LOCAL_BIT"/>
+ <type name="VkRenderPassMultiviewCreateInfoKHR"/>
+ <type name="VkPhysicalDeviceMultiviewFeaturesKHR"/>
+ <type name="VkPhysicalDeviceMultiviewPropertiesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_format_pvrtc" number="55" type="device" author="IMG" contact="Tobias Hector @tobias" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_IMG_FORMAT_PVRTC_SPEC_VERSION"/>
+ <enum value=""VK_IMG_format_pvrtc"" name="VK_IMG_FORMAT_PVRTC_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkFormat" name="VK_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG"/>
+ <enum offset="1" extends="VkFormat" name="VK_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG"/>
+ <enum offset="2" extends="VkFormat" name="VK_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG"/>
+ <enum offset="3" extends="VkFormat" name="VK_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG"/>
+ <enum offset="4" extends="VkFormat" name="VK_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG"/>
+ <enum offset="5" extends="VkFormat" name="VK_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG"/>
+ <enum offset="6" extends="VkFormat" name="VK_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG"/>
+ <enum offset="7" extends="VkFormat" name="VK_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_external_memory_capabilities" number="56" type="instance" author="NV" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION"/>
+ <enum value=""VK_NV_external_memory_capabilities"" name="VK_NV_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME"/>
+ <type name="VkExternalMemoryHandleTypeFlagsNV"/>
+ <type name="VkExternalMemoryHandleTypeFlagBitsNV"/>
+ <type name="VkExternalMemoryFeatureFlagsNV"/>
+ <type name="VkExternalMemoryFeatureFlagBitsNV"/>
+ <type name="VkExternalImageFormatPropertiesNV"/>
+ <command name="vkGetPhysicalDeviceExternalImageFormatPropertiesNV"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_external_memory" number="57" type="device" requires="VK_NV_external_memory_capabilities" author="NV" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_EXTERNAL_MEMORY_SPEC_VERSION"/>
+ <enum value=""VK_NV_external_memory"" name="VK_NV_EXTERNAL_MEMORY_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV"/>
+ <type name="VkExternalMemoryImageCreateInfoNV"/>
+ <type name="VkExportMemoryAllocateInfoNV"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_external_memory_win32" number="58" type="device" requires="VK_NV_external_memory" author="NV" contact="James Jones @cubanismo" platform="win32" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_EXTERNAL_MEMORY_WIN32_SPEC_VERSION"/>
+ <enum value=""VK_NV_external_memory_win32"" name="VK_NV_EXTERNAL_MEMORY_WIN32_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_NV"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_NV"/>
+ <type name="VkImportMemoryWin32HandleInfoNV"/>
+ <type name="VkExportMemoryWin32HandleInfoNV"/>
+ <command name="vkGetMemoryWin32HandleNV"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_win32_keyed_mutex" number="59" type="device" requires="VK_NV_external_memory_win32" author="NV" contact="Carsten Rohde" platform="win32" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_WIN32_KEYED_MUTEX_SPEC_VERSION"/>
+ <enum value=""VK_NV_win32_keyed_mutex"" name="VK_NV_WIN32_KEYED_MUTEX_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_NV"/>
+ <type name="VkWin32KeyedMutexAcquireReleaseInfoNV"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_get_physical_device_properties2" number="60" type="instance" author="KHR" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_SPEC_VERSION"/>
+ <enum value=""VK_KHR_get_physical_device_properties2"" name="VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2_KHR" alias="VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2_KHR" alias="VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2_KHR" alias="VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2_KHR" alias="VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2"/>
+ <type name="VkPhysicalDeviceFeatures2KHR"/>
+ <type name="VkPhysicalDeviceProperties2KHR"/>
+ <type name="VkFormatProperties2KHR"/>
+ <type name="VkImageFormatProperties2KHR"/>
+ <type name="VkPhysicalDeviceImageFormatInfo2KHR"/>
+ <type name="VkQueueFamilyProperties2KHR"/>
+ <type name="VkPhysicalDeviceMemoryProperties2KHR"/>
+ <type name="VkSparseImageFormatProperties2KHR"/>
+ <type name="VkPhysicalDeviceSparseImageFormatInfo2KHR"/>
+ <command name="vkGetPhysicalDeviceFeatures2KHR"/>
+ <command name="vkGetPhysicalDeviceProperties2KHR"/>
+ <command name="vkGetPhysicalDeviceFormatProperties2KHR"/>
+ <command name="vkGetPhysicalDeviceImageFormatProperties2KHR"/>
+ <command name="vkGetPhysicalDeviceQueueFamilyProperties2KHR"/>
+ <command name="vkGetPhysicalDeviceMemoryProperties2KHR"/>
+ <command name="vkGetPhysicalDeviceSparseImageFormatProperties2KHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_device_group" number="61" type="device" author="KHR" requires="VK_KHR_device_group_creation" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="3" name="VK_KHR_DEVICE_GROUP_SPEC_VERSION"/>
+ <enum value=""VK_KHR_device_group"" name="VK_KHR_DEVICE_GROUP_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO_KHR" alias="VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO_KHR" alias="VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO_KHR" alias="VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO_KHR" alias="VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO_KHR" alias="VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO"/>
+ <type name="VkPeerMemoryFeatureFlagsKHR"/>
+ <type name="VkPeerMemoryFeatureFlagBitsKHR"/>
+ <enum extends="VkPeerMemoryFeatureFlagBits" name="VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT_KHR" alias="VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT"/>
+ <enum extends="VkPeerMemoryFeatureFlagBits" name="VK_PEER_MEMORY_FEATURE_COPY_DST_BIT_KHR" alias="VK_PEER_MEMORY_FEATURE_COPY_DST_BIT"/>
+ <enum extends="VkPeerMemoryFeatureFlagBits" name="VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT_KHR" alias="VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT"/>
+ <enum extends="VkPeerMemoryFeatureFlagBits" name="VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT_KHR" alias="VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT"/>
+ <type name="VkMemoryAllocateFlagsKHR"/>
+ <type name="VkMemoryAllocateFlagBitsKHR"/>
+ <enum extends="VkMemoryAllocateFlagBits" name="VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT_KHR" alias="VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT"/>
+ <type name="VkMemoryAllocateFlagsInfoKHR"/>
+ <type name="VkDeviceGroupRenderPassBeginInfoKHR"/>
+ <type name="VkDeviceGroupCommandBufferBeginInfoKHR"/>
+ <type name="VkDeviceGroupSubmitInfoKHR"/>
+ <type name="VkDeviceGroupBindSparseInfoKHR"/>
+ <command name="vkGetDeviceGroupPeerMemoryFeaturesKHR"/>
+ <command name="vkCmdSetDeviceMaskKHR"/>
+ <command name="vkCmdDispatchBaseKHR"/>
+ <enum extends="VkPipelineCreateFlagBits" name="VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT_KHR" alias="VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT"/>
+ <enum extends="VkPipelineCreateFlagBits" name="VK_PIPELINE_CREATE_DISPATCH_BASE_KHR" alias="VK_PIPELINE_CREATE_DISPATCH_BASE"/>
+ <enum extends="VkDependencyFlagBits" name="VK_DEPENDENCY_DEVICE_GROUP_BIT_KHR" alias="VK_DEPENDENCY_DEVICE_GROUP_BIT"/>
+ </require>
+ <require extension="VK_KHR_bind_memory2">
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO_KHR" alias="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO_KHR" alias="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO"/>
+ <type name="VkBindBufferMemoryDeviceGroupInfoKHR"/>
+ <type name="VkBindImageMemoryDeviceGroupInfoKHR"/>
+ <enum extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR" alias="VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT"/>
+ </require>
+ <require extension="VK_KHR_surface">
+ <enum offset="7" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR"/>
+ <type name="VkDeviceGroupPresentModeFlagBitsKHR"/>
+ <type name="VkDeviceGroupPresentModeFlagsKHR"/>
+ <type name="VkDeviceGroupPresentCapabilitiesKHR"/>
+ <command name="vkGetDeviceGroupPresentCapabilitiesKHR"/>
+ <command name="vkGetDeviceGroupSurfacePresentModesKHR"/>
+ <command name="vkGetPhysicalDevicePresentRectanglesKHR"/>
+ </require>
+ <require extension="VK_KHR_swapchain">
+ <enum offset="8" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR"/>
+ <enum offset="9" extends="VkStructureType" name="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR"/>
+ <enum offset="10" extends="VkStructureType" name="VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR"/>
+ <enum offset="11" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR"/>
+ <enum offset="12" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR"/>
+ <enum bitpos="0" extends="VkSwapchainCreateFlagBitsKHR" name="VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR" comment="Allow images with VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT"/>
+ <type name="VkImageSwapchainCreateInfoKHR"/>
+ <type name="VkBindImageMemorySwapchainInfoKHR"/>
+ <type name="VkAcquireNextImageInfoKHR"/>
+ <type name="VkDeviceGroupPresentInfoKHR"/>
+ <type name="VkDeviceGroupSwapchainCreateInfoKHR"/>
+ <command name="vkAcquireNextImage2KHR"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_validation_flags" number="62" type="instance" author="GOOGLE" contact="Tobin Ehlis @tobine" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_VALIDATION_FLAGS_SPEC_VERSION"/>
+ <enum value=""VK_EXT_validation_flags"" name="VK_EXT_VALIDATION_FLAGS_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT"/>
+ <type name="VkValidationFlagsEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_NN_vi_surface" number="63" type="instance" author="NN" contact="Mathias Heyer @mheyer" requires="VK_KHR_surface" platform="vi" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NN_VI_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_NN_vi_surface"" name="VK_NN_VI_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_VI_SURFACE_CREATE_INFO_NN"/>
+ <type name="VkViSurfaceCreateFlagsNN"/>
+ <type name="VkViSurfaceCreateInfoNN"/>
+ <command name="vkCreateViSurfaceNN"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_shader_draw_parameters" number="64" type="device" author="KHR" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_SHADER_DRAW_PARAMETERS_SPEC_VERSION"/>
+ <enum value=""VK_KHR_shader_draw_parameters"" name="VK_KHR_SHADER_DRAW_PARAMETERS_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_shader_subgroup_ballot" number="65" type="device" author="NV" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_SHADER_SUBGROUP_BALLOT_SPEC_VERSION"/>
+ <enum value=""VK_EXT_shader_subgroup_ballot"" name="VK_EXT_SHADER_SUBGROUP_BALLOT_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_shader_subgroup_vote" number="66" type="device" author="NV" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_SHADER_SUBGROUP_VOTE_SPEC_VERSION"/>
+ <enum value=""VK_EXT_shader_subgroup_vote"" name="VK_EXT_SHADER_SUBGROUP_VOTE_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_ARM_extension_01" number="67" type="device" author="ARM" contact="Jan-Harald Fredriksen @janharald" supported="disabled">
+ <require>
+ <enum value="0" name="VK_ARM_EXTENSION_01_SPEC_VERSION"/>
+ <enum value=""VK_ARM_extension_01"" name="VK_ARM_EXTENSION_01_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_ARM_extension_02" number="68" type="device" author="ARM" contact="Jan-Harald Fredriksen @janharald" supported="disabled">
+ <require>
+ <enum value="0" name="VK_ARM_EXTENSION_02_SPEC_VERSION"/>
+ <enum value=""VK_ARM_extension_02"" name="VK_ARM_EXTENSION_02_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_extension_69" number="69" type="device" author="IMG" contact="Tobias Hector @tobias" supported="disabled">
+ <require>
+ <enum value="0" name="VK_IMG_EXTENSION_69_SPEC_VERSION"/>
+ <enum value=""VK_IMG_extension_69"" name="VK_IMG_EXTENSION_69_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_maintenance1" number="70" type="device" author="KHR" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="2" name="VK_KHR_MAINTENANCE1_SPEC_VERSION"/>
+ <enum value=""VK_KHR_maintenance1"" name="VK_KHR_MAINTENANCE1_EXTENSION_NAME"/>
+ <enum extends="VkResult" name="VK_ERROR_OUT_OF_POOL_MEMORY_KHR" alias="VK_ERROR_OUT_OF_POOL_MEMORY"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_TRANSFER_SRC_BIT_KHR" alias="VK_FORMAT_FEATURE_TRANSFER_SRC_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_TRANSFER_DST_BIT_KHR" alias="VK_FORMAT_FEATURE_TRANSFER_DST_BIT"/>
+ <enum extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT_KHR" alias="VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT"/>
+ <type name="VkCommandPoolTrimFlagsKHR"/>
+ <command name="vkTrimCommandPoolKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_device_group_creation" number="71" type="instance" author="KHR" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_DEVICE_GROUP_CREATION_SPEC_VERSION"/>
+ <enum value=""VK_KHR_device_group_creation"" name="VK_KHR_DEVICE_GROUP_CREATION_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GROUP_PROPERTIES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO"/>
+ <enum name="VK_MAX_DEVICE_GROUP_SIZE_KHR"/>
+ <type name="VkPhysicalDeviceGroupPropertiesKHR"/>
+ <type name="VkDeviceGroupDeviceCreateInfoKHR"/>
+ <command name="vkEnumeratePhysicalDeviceGroupsKHR"/>
+ <enum extends="VkMemoryHeapFlagBits" name="VK_MEMORY_HEAP_MULTI_INSTANCE_BIT_KHR" alias="VK_MEMORY_HEAP_MULTI_INSTANCE_BIT"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_memory_capabilities" number="72" type="instance" author="KHR" requires="VK_KHR_get_physical_device_properties2" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_memory_capabilities"" name="VK_KHR_EXTERNAL_MEMORY_CAPABILITIES_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES"/>
+ <enum name="VK_LUID_SIZE_KHR"/>
+ <type name="VkExternalMemoryHandleTypeFlagsKHR"/>
+ <type name="VkExternalMemoryHandleTypeFlagBitsKHR"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT"/>
+ <enum extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT_KHR" alias="VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT"/>
+ <type name="VkExternalMemoryFeatureFlagsKHR"/>
+ <type name="VkExternalMemoryFeatureFlagBitsKHR"/>
+ <enum extends="VkExternalMemoryFeatureFlagBits" name="VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_KHR" alias="VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT"/>
+ <enum extends="VkExternalMemoryFeatureFlagBits" name="VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_KHR" alias="VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT"/>
+ <enum extends="VkExternalMemoryFeatureFlagBits" name="VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_KHR" alias="VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT"/>
+ <type name="VkExternalMemoryPropertiesKHR"/>
+ <type name="VkPhysicalDeviceExternalImageFormatInfoKHR"/>
+ <type name="VkExternalImageFormatPropertiesKHR"/>
+ <type name="VkPhysicalDeviceExternalBufferInfoKHR"/>
+ <type name="VkExternalBufferPropertiesKHR"/>
+ <type name="VkPhysicalDeviceIDPropertiesKHR"/>
+ <command name="vkGetPhysicalDeviceExternalBufferPropertiesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_memory" number="73" type="device" requires="VK_KHR_external_memory_capabilities" author="KHR" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_MEMORY_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_memory"" name="VK_KHR_EXTERNAL_MEMORY_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO"/>
+ <enum extends="VkResult" name="VK_ERROR_INVALID_EXTERNAL_HANDLE_KHR" alias="VK_ERROR_INVALID_EXTERNAL_HANDLE"/>
+ <enum name="VK_QUEUE_FAMILY_EXTERNAL_KHR"/>
+ <type name="VkExternalMemoryImageCreateInfoKHR"/>
+ <type name="VkExternalMemoryBufferCreateInfoKHR"/>
+ <type name="VkExportMemoryAllocateInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_memory_win32" number="74" type="device" requires="VK_KHR_external_memory" author="KHR" contact="James Jones @cubanismo" platform="win32" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_MEMORY_WIN32_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_memory_win32"" name="VK_KHR_EXTERNAL_MEMORY_WIN32_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_MEMORY_WIN32_HANDLE_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_MEMORY_WIN32_HANDLE_INFO_KHR"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_WIN32_HANDLE_PROPERTIES_KHR"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_GET_WIN32_HANDLE_INFO_KHR"/>
+ <type name="VkImportMemoryWin32HandleInfoKHR"/>
+ <type name="VkExportMemoryWin32HandleInfoKHR"/>
+ <type name="VkMemoryWin32HandlePropertiesKHR"/>
+ <type name="VkMemoryGetWin32HandleInfoKHR"/>
+ <command name="vkGetMemoryWin32HandleKHR"/>
+ <command name="vkGetMemoryWin32HandlePropertiesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_memory_fd" number="75" type="device" requires="VK_KHR_external_memory" author="KHR" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_MEMORY_FD_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_memory_fd"" name="VK_KHR_EXTERNAL_MEMORY_FD_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_FD_PROPERTIES_KHR"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR"/>
+ <type name="VkImportMemoryFdInfoKHR"/>
+ <type name="VkMemoryFdPropertiesKHR"/>
+ <type name="VkMemoryGetFdInfoKHR"/>
+ <command name="vkGetMemoryFdKHR"/>
+ <command name="vkGetMemoryFdPropertiesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_win32_keyed_mutex" number="76" type="device" requires="VK_KHR_external_memory_win32" author="KHR" contact="Carsten Rohde" platform="win32" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_WIN32_KEYED_MUTEX_SPEC_VERSION"/>
+ <enum value=""VK_KHR_win32_keyed_mutex"" name="VK_KHR_WIN32_KEYED_MUTEX_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_WIN32_KEYED_MUTEX_ACQUIRE_RELEASE_INFO_KHR"/>
+ <type name="VkWin32KeyedMutexAcquireReleaseInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_semaphore_capabilities" number="77" type="instance" author="KHR" requires="VK_KHR_get_physical_device_properties2" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_SEMAPHORE_CAPABILITIES_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_semaphore_capabilities"" name="VK_KHR_EXTERNAL_SEMAPHORE_CAPABILITIES_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES"/>
+ <enum name="VK_LUID_SIZE_KHR"/>
+ <type name="VkExternalSemaphoreHandleTypeFlagsKHR"/>
+ <type name="VkExternalSemaphoreHandleTypeFlagBitsKHR"/>
+ <enum extends="VkExternalSemaphoreHandleTypeFlagBits" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT"/>
+ <enum extends="VkExternalSemaphoreHandleTypeFlagBits" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT"/>
+ <enum extends="VkExternalSemaphoreHandleTypeFlagBits" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT"/>
+ <enum extends="VkExternalSemaphoreHandleTypeFlagBits" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT"/>
+ <enum extends="VkExternalSemaphoreHandleTypeFlagBits" name="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT"/>
+ <type name="VkExternalSemaphoreFeatureFlagsKHR"/>
+ <type name="VkExternalSemaphoreFeatureFlagBitsKHR"/>
+ <enum extends="VkExternalSemaphoreFeatureFlagBits" name="VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT"/>
+ <enum extends="VkExternalSemaphoreFeatureFlagBits" name="VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT_KHR" alias="VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT"/>
+ <type name="VkPhysicalDeviceExternalSemaphoreInfoKHR"/>
+ <type name="VkExternalSemaphorePropertiesKHR"/>
+ <type name="VkPhysicalDeviceIDPropertiesKHR"/>
+ <command name="vkGetPhysicalDeviceExternalSemaphorePropertiesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_semaphore" number="78" type="device" requires="VK_KHR_external_semaphore_capabilities" author="KHR" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_SEMAPHORE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_semaphore"" name="VK_KHR_EXTERNAL_SEMAPHORE_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO"/>
+ <type name="VkSemaphoreImportFlagsKHR"/>
+ <type name="VkSemaphoreImportFlagBitsKHR"/>
+ <enum extends="VkSemaphoreImportFlagBits" name="VK_SEMAPHORE_IMPORT_TEMPORARY_BIT_KHR" alias="VK_SEMAPHORE_IMPORT_TEMPORARY_BIT"/>
+ <type name="VkExportSemaphoreCreateInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_semaphore_win32" number="79" type="device" requires="VK_KHR_external_semaphore" author="KHR" contact="James Jones @cubanismo" platform="win32" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_SEMAPHORE_WIN32_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_semaphore_win32"" name="VK_KHR_EXTERNAL_SEMAPHORE_WIN32_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_WIN32_HANDLE_INFO_KHR"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_D3D12_FENCE_SUBMIT_INFO_KHR"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SEMAPHORE_GET_WIN32_HANDLE_INFO_KHR"/>
+ <type name="VkImportSemaphoreWin32HandleInfoKHR"/>
+ <type name="VkExportSemaphoreWin32HandleInfoKHR"/>
+ <type name="VkD3D12FenceSubmitInfoKHR"/>
+ <type name="VkSemaphoreGetWin32HandleInfoKHR"/>
+ <command name="vkImportSemaphoreWin32HandleKHR"/>
+ <command name="vkGetSemaphoreWin32HandleKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_semaphore_fd" number="80" type="device" requires="VK_KHR_external_semaphore" author="KHR" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_SEMAPHORE_FD_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_semaphore_fd"" name="VK_KHR_EXTERNAL_SEMAPHORE_FD_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR"/>
+ <type name="VkImportSemaphoreFdInfoKHR"/>
+ <type name="VkSemaphoreGetFdInfoKHR"/>
+ <command name="vkImportSemaphoreFdKHR"/>
+ <command name="vkGetSemaphoreFdKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_push_descriptor" number="81" type="device" author="KHR" requires="VK_KHR_get_physical_device_properties2" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="2" name="VK_KHR_PUSH_DESCRIPTOR_SPEC_VERSION"/>
+ <enum value=""VK_KHR_push_descriptor"" name="VK_KHR_PUSH_DESCRIPTOR_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR"/>
+ <enum bitpos="0" extends="VkDescriptorSetLayoutCreateFlagBits" name="VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR" comment="Descriptors are pushed via flink:vkCmdPushDescriptorSetKHR"/>
+ <command name="vkCmdPushDescriptorSetKHR"/>
+ <type name="VkPhysicalDevicePushDescriptorPropertiesKHR"/>
+ </require>
+ <require feature="VK_VERSION_1_1">
+ <command name="vkCmdPushDescriptorSetWithTemplateKHR"/>
+ <enum value="1" extends="VkDescriptorUpdateTemplateType" name="VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR" comment="Create descriptor update template for pushed descriptor updates"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_82" number="82" type="device" author="EXT" contact="Piers Daniell @pdaniell" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_82_SPEC_VERSION"/>
+ <enum value=""VK_EXT_extension_82"" name="VK_EXT_EXTENSION_82_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_83" number="83" author="KHR" contact="Jan-Harald Fredriksen @janharald" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_83_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_83"" name="VK_KHR_EXTENSION_83_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_16bit_storage" number="84" type="device" requires="VK_KHR_get_physical_device_properties2,VK_KHR_storage_buffer_storage_class" author="KHR" contact="Jan-Harald Fredriksen @janharald" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_16BIT_STORAGE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_16bit_storage"" name="VK_KHR_16BIT_STORAGE_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES"/>
+ <type name="VkPhysicalDevice16BitStorageFeaturesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_incremental_present" number="85" type="device" author="KHR" requires="VK_KHR_swapchain" contact="Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_INCREMENTAL_PRESENT_SPEC_VERSION"/>
+ <enum value=""VK_KHR_incremental_present"" name="VK_KHR_INCREMENTAL_PRESENT_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR"/>
+ <type name="VkPresentRegionsKHR"/>
+ <type name="VkPresentRegionKHR"/>
+ <type name="VkRectLayerKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_descriptor_update_template" number="86" type="device" author="KHR" contact="Markus Tavenrath @mtavenrath" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_DESCRIPTOR_UPDATE_TEMPLATE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_descriptor_update_template"" name="VK_KHR_DESCRIPTOR_UPDATE_TEMPLATE_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO"/>
+ <enum extends="VkObjectType" name="VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_KHR" alias="VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE"/>
+ <command name="vkCreateDescriptorUpdateTemplateKHR"/>
+ <command name="vkDestroyDescriptorUpdateTemplateKHR"/>
+ <command name="vkUpdateDescriptorSetWithTemplateKHR"/>
+ <type name="VkDescriptorUpdateTemplateKHR"/>
+ <type name="VkDescriptorUpdateTemplateCreateFlagsKHR"/>
+ <type name="VkDescriptorUpdateTemplateTypeKHR"/>
+ <type name="VkDescriptorUpdateTemplateEntryKHR"/>
+ <type name="VkDescriptorUpdateTemplateCreateInfoKHR"/>
+ <enum extends="VkDescriptorUpdateTemplateType" name="VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET_KHR" alias="VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET"/>
+ </require>
+ <require extension="VK_KHR_push_descriptor">
+ <command name="vkCmdPushDescriptorSetWithTemplateKHR"/>
+ <enum value="1" extends="VkDescriptorUpdateTemplateType" name="VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR" comment="Create descriptor update template for pushed descriptor updates"/>
+ </require>
+ <require extension="VK_EXT_debug_report">
+ <enum extends="VkDebugReportObjectTypeEXT" name="VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_KHR_EXT" alias="VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_device_generated_commands" number="87" type="device" author="NVX" contact="Christoph Kubisch @pixeljetstream" supported="vulkan">
+ <require>
+ <enum value="3" name="VK_NVX_DEVICE_GENERATED_COMMANDS_SPEC_VERSION"/>
+ <enum value=""VK_NVX_device_generated_commands"" name="VK_NVX_DEVICE_GENERATED_COMMANDS_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX"/>
+ <enum offset="4" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX"/>
+ <enum offset="5" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX"/>
+ <enum bitpos="17" extends="VkPipelineStageFlagBits" name="VK_PIPELINE_STAGE_COMMAND_PROCESS_BIT_NVX"/>
+ <enum bitpos="17" extends="VkAccessFlagBits" name="VK_ACCESS_COMMAND_PROCESS_READ_BIT_NVX"/>
+ <enum bitpos="18" extends="VkAccessFlagBits" name="VK_ACCESS_COMMAND_PROCESS_WRITE_BIT_NVX"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_OBJECT_TABLE_NVX" comment="VkobjectTableNVX"/>
+ <enum offset="1" extends="VkObjectType" name="VK_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT_NVX" comment="VkIndirectCommandsLayoutNVX"/>
+ <type name="VkObjectTableNVX"/>
+ <type name="VkIndirectCommandsLayoutNVX"/>
+ <type name="VkIndirectCommandsLayoutUsageFlagsNVX"/>
+ <type name="VkObjectEntryUsageFlagsNVX"/>
+ <type name="VkIndirectCommandsLayoutUsageFlagBitsNVX"/>
+ <type name="VkIndirectCommandsTokenTypeNVX"/>
+ <type name="VkObjectEntryUsageFlagBitsNVX"/>
+ <type name="VkObjectEntryTypeNVX"/>
+ <type name="VkDeviceGeneratedCommandsFeaturesNVX"/>
+ <type name="VkDeviceGeneratedCommandsLimitsNVX"/>
+ <type name="VkIndirectCommandsTokenNVX"/>
+ <type name="VkIndirectCommandsLayoutTokenNVX"/>
+ <type name="VkIndirectCommandsLayoutCreateInfoNVX"/>
+ <type name="VkCmdProcessCommandsInfoNVX"/>
+ <type name="VkCmdReserveSpaceForCommandsInfoNVX"/>
+ <type name="VkObjectTableCreateInfoNVX"/>
+ <type name="VkObjectTableEntryNVX"/>
+ <type name="VkObjectTablePipelineEntryNVX"/>
+ <type name="VkObjectTableDescriptorSetEntryNVX"/>
+ <type name="VkObjectTableVertexBufferEntryNVX"/>
+ <type name="VkObjectTableIndexBufferEntryNVX"/>
+ <type name="VkObjectTablePushConstantEntryNVX"/>
+ <command name="vkCmdProcessCommandsNVX"/>
+ <command name="vkCmdReserveSpaceForCommandsNVX"/>
+ <command name="vkCreateIndirectCommandsLayoutNVX"/>
+ <command name="vkDestroyIndirectCommandsLayoutNVX"/>
+ <command name="vkCreateObjectTableNVX"/>
+ <command name="vkDestroyObjectTableNVX"/>
+ <command name="vkRegisterObjectsNVX"/>
+ <command name="vkUnregisterObjectsNVX"/>
+ <command name="vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_clip_space_w_scaling" number="88" type="device" author="NV" contact="Eric Werness @ewerness" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_CLIP_SPACE_W_SCALING_SPEC_VERSION"/>
+ <enum value=""VK_NV_clip_space_w_scaling"" name="VK_NV_CLIP_SPACE_W_SCALING_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV"/>
+ <enum offset="0" extends="VkDynamicState" name="VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV"/>
+ <type name="VkViewportWScalingNV"/>
+ <type name="VkPipelineViewportWScalingStateCreateInfoNV"/>
+ <command name="vkCmdSetViewportWScalingNV"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_direct_mode_display" number="89" type="instance" requires="VK_KHR_display" author="NV" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_DIRECT_MODE_DISPLAY_SPEC_VERSION"/>
+ <enum value=""VK_EXT_direct_mode_display"" name="VK_EXT_DIRECT_MODE_DISPLAY_EXTENSION_NAME"/>
+ <command name="vkReleaseDisplayEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_acquire_xlib_display" number="90" type="instance" requires="VK_EXT_direct_mode_display" author="NV" contact="James Jones @cubanismo" platform="xlib_xrandr" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_ACQUIRE_XLIB_DISPLAY_SPEC_VERSION"/>
+ <enum value=""VK_EXT_acquire_xlib_display"" name="VK_EXT_ACQUIRE_XLIB_DISPLAY_EXTENSION_NAME"/>
+ <command name="vkAcquireXlibDisplayEXT"/>
+ <command name="vkGetRandROutputDisplayEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_display_surface_counter" number="91" type="instance" requires="VK_KHR_display" author="NV" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_DISPLAY_SURFACE_COUNTER_SPEC_VERSION"/>
+ <enum value=""VK_EXT_display_surface_counter"" name="VK_EXT_DISPLAY_SURFACE_COUNTER_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT"/>
+ <enum value="VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT" name="VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES2_EXT"/>
+ <type name="VkSurfaceCounterFlagsEXT"/>
+ <type name="VkSurfaceCounterFlagBitsEXT"/>
+ <type name="VkSurfaceCapabilities2EXT"/>
+ <command name="vkGetPhysicalDeviceSurfaceCapabilities2EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_display_control" number="92" type="device" requires="VK_EXT_display_surface_counter,VK_KHR_swapchain" author="NV" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_DISPLAY_CONTROL_SPEC_VERSION"/>
+ <enum value=""VK_EXT_display_control"" name="VK_EXT_DISPLAY_CONTROL_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT"/>
+ <type name="VkDisplayPowerStateEXT"/>
+ <type name="VkDeviceEventTypeEXT"/>
+ <type name="VkDisplayEventTypeEXT"/>
+ <type name="VkDisplayPowerInfoEXT"/>
+ <type name="VkDeviceEventInfoEXT"/>
+ <type name="VkDisplayEventInfoEXT"/>
+ <type name="VkSwapchainCounterCreateInfoEXT"/>
+ <command name="vkDisplayPowerControlEXT"/>
+ <command name="vkRegisterDeviceEventEXT"/>
+ <command name="vkRegisterDisplayEventEXT"/>
+ <command name="vkGetSwapchainCounterEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_display_timing" number="93" type="device" author="GOOGLE" requires="VK_KHR_swapchain" contact="Ian Elliott ianelliott@google.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_GOOGLE_DISPLAY_TIMING_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_display_timing"" name="VK_GOOGLE_DISPLAY_TIMING_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE"/>
+ <type name="VkRefreshCycleDurationGOOGLE"/>
+ <type name="VkPastPresentationTimingGOOGLE"/>
+ <type name="VkPresentTimesInfoGOOGLE"/>
+ <type name="VkPresentTimeGOOGLE"/>
+ <command name="vkGetRefreshCycleDurationGOOGLE"/>
+ <command name="vkGetPastPresentationTimingGOOGLE"/>
+ </require>
+ </extension>
+ <extension name="RESERVED_DO_NOT_USE_94" number="94" supported="disabled" comment="Used for functionality subsumed into Vulkan 1.1 and not published as an extension">
+ </extension>
+ <extension name="VK_NV_sample_mask_override_coverage" number="95" type="device" author="NV" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_SPEC_VERSION"/>
+ <enum value=""VK_NV_sample_mask_override_coverage"" name="VK_NV_SAMPLE_MASK_OVERRIDE_COVERAGE_EXTENSION_NAME"/>
+ <comment>
+ enum offset=0 was mistakenly used for the 1.1 core enum
+ VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES
+ (value=1000094000). Fortunately, no conflict resulted.
+ </comment>
+ </require>
+ </extension>
+ <extension name="VK_NV_geometry_shader_passthrough" number="96" type="device" author="NV" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_GEOMETRY_SHADER_PASSTHROUGH_SPEC_VERSION"/>
+ <enum value=""VK_NV_geometry_shader_passthrough"" name="VK_NV_GEOMETRY_SHADER_PASSTHROUGH_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_viewport_array2" number="97" type="device" author="NV" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_VIEWPORT_ARRAY2_SPEC_VERSION"/>
+ <enum value=""VK_NV_viewport_array2"" name="VK_NV_VIEWPORT_ARRAY2_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NVX_multiview_per_view_attributes" number="98" type="device" requires="VK_KHR_multiview" author="NVX" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NVX_MULTIVIEW_PER_VIEW_ATTRIBUTES_SPEC_VERSION"/>
+ <enum value=""VK_NVX_multiview_per_view_attributes"" name="VK_NVX_MULTIVIEW_PER_VIEW_ATTRIBUTES_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX"/>
+ <enum bitpos="0" extends="VkSubpassDescriptionFlagBits" name="VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX"/>
+ <enum bitpos="1" extends="VkSubpassDescriptionFlagBits" name="VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX"/>
+ <type name="VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_viewport_swizzle" number="99" type="device" author="NV" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_VIEWPORT_SWIZZLE_SPEC_VERSION"/>
+ <enum value=""VK_NV_viewport_swizzle"" name="VK_NV_VIEWPORT_SWIZZLE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV"/>
+ <type name="VkViewportSwizzleNV"/>
+ <type name="VkViewportCoordinateSwizzleNV"/>
+ <type name="VkPipelineViewportSwizzleStateCreateInfoNV"/>
+ <type name="VkPipelineViewportSwizzleStateCreateFlagsNV"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_discard_rectangles" number="100" type="device" requires="VK_KHR_get_physical_device_properties2" author="NV" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_DISCARD_RECTANGLES_SPEC_VERSION"/>
+ <enum value=""VK_EXT_discard_rectangles"" name="VK_EXT_DISCARD_RECTANGLES_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT"/>
+ <enum offset="0" extends="VkDynamicState" name="VK_DYNAMIC_STATE_DISCARD_RECTANGLE_EXT"/>
+ <type name="VkPhysicalDeviceDiscardRectanglePropertiesEXT"/>
+ <type name="VkPipelineDiscardRectangleStateCreateInfoEXT"/>
+ <type name="VkPipelineDiscardRectangleStateCreateFlagsEXT"/>
+ <type name="VkDiscardRectangleModeEXT"/>
+ <command name="vkCmdSetDiscardRectangleEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_101" number="101" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_101_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_101"" name="VK_NV_EXTENSION_101_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_conservative_rasterization" number="102" type="device" requires="VK_KHR_get_physical_device_properties2" author="NV" contact="Piers Daniell @pdaniell" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_CONSERVATIVE_RASTERIZATION_SPEC_VERSION"/>
+ <enum value=""VK_EXT_conservative_rasterization"" name="VK_EXT_CONSERVATIVE_RASTERIZATION_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT"/>
+ <type name="VkPhysicalDeviceConservativeRasterizationPropertiesEXT"/>
+ <type name="VkPipelineRasterizationConservativeStateCreateInfoEXT"/>
+ <type name="VkPipelineRasterizationConservativeStateCreateFlagsEXT"/>
+ <type name="VkConservativeRasterizationModeEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_103" number="103" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_103_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_103"" name="VK_NV_EXTENSION_103_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_104" number="104" author="NV" contact="Mathias Schott @mschott" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_104_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_104"" name="VK_NV_EXTENSION_104_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_swapchain_colorspace" number="105" type="instance" author="GOOGLE" contact="Courtney Goeltzenleuchter @courtneygo" requires="VK_KHR_surface" supported="vulkan">
+ <require>
+ <enum value="3" name="VK_EXT_SWAPCHAIN_COLOR_SPACE_SPEC_VERSION"/>
+ <enum value=""VK_EXT_swapchain_colorspace"" name="VK_EXT_SWAPCHAIN_COLOR_SPACE_EXTENSION_NAME"/>
+ <enum offset="1" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT"/>
+ <enum offset="2" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT"/>
+ <enum offset="3" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_DCI_P3_LINEAR_EXT"/>
+ <enum offset="4" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_DCI_P3_NONLINEAR_EXT"/>
+ <enum offset="5" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_BT709_LINEAR_EXT"/>
+ <enum offset="6" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_BT709_NONLINEAR_EXT"/>
+ <enum offset="7" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_BT2020_LINEAR_EXT"/>
+ <enum offset="8" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_HDR10_ST2084_EXT"/>
+ <enum offset="9" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_DOLBYVISION_EXT"/>
+ <enum offset="10" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_HDR10_HLG_EXT"/>
+ <enum offset="11" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_ADOBERGB_LINEAR_EXT"/>
+ <enum offset="12" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_ADOBERGB_NONLINEAR_EXT"/>
+ <enum offset="13" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_PASS_THROUGH_EXT"/>
+ <enum offset="14" extends="VkColorSpaceKHR" name="VK_COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_hdr_metadata" number="106" type="device" requires="VK_KHR_swapchain" author="GOOGLE" contact="Courtney Goeltzenleuchter @courtneygo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_HDR_METADATA_SPEC_VERSION"/>
+ <enum value=""VK_EXT_hdr_metadata"" name="VK_EXT_HDR_METADATA_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_HDR_METADATA_EXT"/>
+ <type name="VkHdrMetadataEXT"/>
+ <type name="VkXYColorEXT"/>
+ <command name="vkSetHdrMetadataEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_extension_107" number="107" author="IMG" contact="Michael Worcester @michaelworcester" supported="disabled">
+ <require>
+ <enum value="0" name="VK_IMG_EXTENSION_107_SPEC_VERSION"/>
+ <enum value=""VK_IMG_extension_107"" name="VK_IMG_EXTENSION_107_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_extension_108" number="108" author="IMG" contact="Michael Worcester @michaelworcester" supported="disabled">
+ <require>
+ <enum value="0" name="VK_IMG_EXTENSION_108_SPEC_VERSION"/>
+ <enum value=""VK_IMG_extension_108"" name="VK_IMG_EXTENSION_108_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_extension_109" number="109" author="IMG" contact="Michael Worcester @michaelworcester" supported="disabled">
+ <require>
+ <enum value="0" name="VK_IMG_EXTENSION_109_SPEC_VERSION"/>
+ <enum value=""VK_IMG_extension_109"" name="VK_IMG_EXTENSION_109_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_extension_110" number="110" author="IMG" contact="Michael Worcester @michaelworcester" supported="disabled">
+ <require>
+ <enum value="0" name="VK_IMG_EXTENSION_110_SPEC_VERSION"/>
+ <enum value=""VK_IMG_extension_110"" name="VK_IMG_EXTENSION_110_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_IMG_extension_111" number="111" author="IMG" contact="Michael Worcester @michaelworcester" supported="disabled">
+ <require>
+ <enum value="0" name="VK_IMG_EXTENSION_111_SPEC_VERSION"/>
+ <enum value=""VK_IMG_extension_111"" name="VK_IMG_EXTENSION_111_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_shared_presentable_image" number="112" type="device" requires="VK_KHR_swapchain,VK_KHR_get_physical_device_properties2,VK_KHR_get_surface_capabilities2" author="KHR" contact="Alon Or-bach @alonorbach" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_SHARED_PRESENTABLE_IMAGE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_shared_presentable_image"" name="VK_KHR_SHARED_PRESENTABLE_IMAGE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR"/>
+ <enum offset="0" extends="VkPresentModeKHR" name="VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR"/>
+ <enum offset="1" extends="VkPresentModeKHR" name="VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR"/>
+ <enum offset="0" extends="VkImageLayout" name="VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR"/>
+ <type name="VkSharedPresentSurfaceCapabilitiesKHR"/>
+ <command name="vkGetSwapchainStatusKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_fence_capabilities" number="113" type="instance" author="KHR" requires="VK_KHR_get_physical_device_properties2" contact="Jesse Hall @jessehall" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_FENCE_CAPABILITIES_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_fence_capabilities"" name="VK_KHR_EXTERNAL_FENCE_CAPABILITIES_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES"/>
+ <enum name="VK_LUID_SIZE_KHR"/>
+ <type name="VkExternalFenceHandleTypeFlagsKHR"/>
+ <type name="VkExternalFenceHandleTypeFlagBitsKHR"/>
+ <enum extends="VkExternalFenceHandleTypeFlagBits" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT_KHR" alias="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT"/>
+ <enum extends="VkExternalFenceHandleTypeFlagBits" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR" alias="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT"/>
+ <enum extends="VkExternalFenceHandleTypeFlagBits" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR" alias="VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT"/>
+ <enum extends="VkExternalFenceHandleTypeFlagBits" name="VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT_KHR" alias="VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT"/>
+ <type name="VkExternalFenceFeatureFlagsKHR"/>
+ <type name="VkExternalFenceFeatureFlagBitsKHR"/>
+ <enum extends="VkExternalFenceFeatureFlagBits" name="VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT_KHR" alias="VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT"/>
+ <enum extends="VkExternalFenceFeatureFlagBits" name="VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT_KHR" alias="VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT"/>
+ <type name="VkPhysicalDeviceExternalFenceInfoKHR"/>
+ <type name="VkExternalFencePropertiesKHR"/>
+ <type name="VkPhysicalDeviceIDPropertiesKHR"/>
+ <command name="vkGetPhysicalDeviceExternalFencePropertiesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_fence" number="114" type="device" requires="VK_KHR_external_fence_capabilities" author="KHR" contact="Jesse Hall @jessehall" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_FENCE_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_fence"" name="VK_KHR_EXTERNAL_FENCE_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO"/>
+ <type name="VkFenceImportFlagsKHR"/>
+ <type name="VkFenceImportFlagBitsKHR"/>
+ <enum extends="VkFenceImportFlagBits" name="VK_FENCE_IMPORT_TEMPORARY_BIT_KHR" alias="VK_FENCE_IMPORT_TEMPORARY_BIT"/>
+ <type name="VkExportFenceCreateInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_fence_win32" number="115" type="device" requires="VK_KHR_external_fence" author="KHR" contact="Jesse Hall @jessehall" platform="win32" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_FENCE_WIN32_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_fence_win32"" name="VK_KHR_EXTERNAL_FENCE_WIN32_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_FENCE_WIN32_HANDLE_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXPORT_FENCE_WIN32_HANDLE_INFO_KHR"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_FENCE_GET_WIN32_HANDLE_INFO_KHR"/>
+ <type name="VkImportFenceWin32HandleInfoKHR"/>
+ <type name="VkExportFenceWin32HandleInfoKHR"/>
+ <type name="VkFenceGetWin32HandleInfoKHR"/>
+ <command name="vkImportFenceWin32HandleKHR"/>
+ <command name="vkGetFenceWin32HandleKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_external_fence_fd" number="116" type="device" requires="VK_KHR_external_fence" author="KHR" contact="Jesse Hall @jessehall" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_EXTERNAL_FENCE_FD_SPEC_VERSION"/>
+ <enum value=""VK_KHR_external_fence_fd"" name="VK_KHR_EXTERNAL_FENCE_FD_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR"/>
+ <type name="VkImportFenceFdInfoKHR"/>
+ <type name="VkFenceGetFdInfoKHR"/>
+ <command name="vkImportFenceFdKHR"/>
+ <command name="vkGetFenceFdKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_117" number="117" author="KHR" contact="Kenneth Benzie @kbenzie" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_117_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_117"" name="VK_KHR_EXTENSION_117_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_maintenance2" number="118" type="device" author="KHR" contact="Michael Worcester @michaelworcester" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_MAINTENANCE2_SPEC_VERSION"/>
+ <enum value=""VK_KHR_maintenance2"" name="VK_KHR_MAINTENANCE2_EXTENSION_NAME"/>
+ <enum extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT_KHR" alias="VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT"/>
+ <enum extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_EXTENDED_USAGE_BIT_KHR" alias="VK_IMAGE_CREATE_EXTENDED_USAGE_BIT"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO"/>
+ <enum extends="VkImageLayout" name="VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL_KHR" alias="VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL"/>
+ <enum extends="VkImageLayout" name="VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL_KHR" alias="VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL"/>
+ <type name="VkPhysicalDevicePointClippingPropertiesKHR"/>
+ <type name="VkPointClippingBehaviorKHR"/>
+ <enum extends="VkPointClippingBehavior" name="VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES_KHR" alias="VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES"/>
+ <enum extends="VkPointClippingBehavior" name="VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY_KHR" alias="VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY"/>
+ <type name="VkRenderPassInputAttachmentAspectCreateInfoKHR"/>
+ <type name="VkInputAttachmentAspectReferenceKHR"/>
+ <type name="VkImageViewUsageCreateInfoKHR"/>
+ <type name="VkTessellationDomainOriginKHR"/>
+ <enum extends="VkTessellationDomainOrigin" name="VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT_KHR" alias="VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT"/>
+ <enum extends="VkTessellationDomainOrigin" name="VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT_KHR" alias="VK_TESSELLATION_DOMAIN_ORIGIN_LOWER_LEFT"/>
+ <type name="VkPipelineTessellationDomainOriginStateCreateInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_119" number="119" author="KHR" contact="Michael Worcester @michaelworcester" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_119_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_119"" name="VK_KHR_EXTENSION_119_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_get_surface_capabilities2" number="120" type="instance" requires="VK_KHR_surface" author="KHR" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_GET_SURFACE_CAPABILITIES_2_SPEC_VERSION"/>
+ <enum value=""VK_KHR_get_surface_capabilities2"" name="VK_KHR_GET_SURFACE_CAPABILITIES_2_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR"/>
+ <type name="VkPhysicalDeviceSurfaceInfo2KHR"/>
+ <type name="VkSurfaceCapabilities2KHR"/>
+ <type name="VkSurfaceFormat2KHR"/>
+ <command name="vkGetPhysicalDeviceSurfaceCapabilities2KHR"/>
+ <command name="vkGetPhysicalDeviceSurfaceFormats2KHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_variable_pointers" number="121" type="device" author="KHR" contact="Jesse Hall @jessehall" requires="VK_KHR_get_physical_device_properties2,VK_KHR_storage_buffer_storage_class" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_VARIABLE_POINTERS_SPEC_VERSION"/>
+ <enum value=""VK_KHR_variable_pointers"" name="VK_KHR_VARIABLE_POINTERS_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES"/>
+ <type name="VkPhysicalDeviceVariablePointerFeaturesKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_122" number="122" author="KHR" contact="James Jones @cubanismo" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_122_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_122"" name="VK_KHR_EXTENSION_122_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_MVK_ios_surface" number="123" type="instance" requires="VK_KHR_surface" platform="ios" supported="vulkan" author="MVK" contact="Bill Hollings @billhollings">
+ <require>
+ <enum value="2" name="VK_MVK_IOS_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_MVK_ios_surface"" name="VK_MVK_IOS_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IOS_SURFACE_CREATE_INFO_MVK"/>
+ <type name="VkIOSSurfaceCreateFlagsMVK"/>
+ <type name="VkIOSSurfaceCreateInfoMVK"/>
+ <command name="vkCreateIOSSurfaceMVK"/>
+ </require>
+ </extension>
+ <extension name="VK_MVK_macos_surface" number="124" type="instance" requires="VK_KHR_surface" platform="macos" supported="vulkan" author="MVK" contact="Bill Hollings @billhollings">
+ <require>
+ <enum value="2" name="VK_MVK_MACOS_SURFACE_SPEC_VERSION"/>
+ <enum value=""VK_MVK_macos_surface"" name="VK_MVK_MACOS_SURFACE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK"/>
+ <type name="VkMacOSSurfaceCreateFlagsMVK"/>
+ <type name="VkMacOSSurfaceCreateInfoMVK"/>
+ <command name="vkCreateMacOSSurfaceMVK"/>
+ </require>
+ </extension>
+ <extension name="VK_MVK_moltenvk" number="125" type="instance" author="MVK" contact="Bill Hollings @billhollings" supported="disabled">
+ <require>
+ <enum value="0" name="VK_MVK_MOLTENVK_SPEC_VERSION"/>
+ <enum value=""VK_MVK_moltenvk"" name="VK_MVK_MOLTENVK_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_external_memory_dma_buf" number="126" type="device" requires="VK_KHR_external_memory_fd" author="EXT" contact="Chad Versace @chadversary" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_EXTERNAL_MEMORY_DMA_BUF_SPEC_VERSION"/>
+ <enum value=""VK_EXT_external_memory_dma_buf"" name="VK_EXT_EXTERNAL_MEMORY_DMA_BUF_EXTENSION_NAME"/>
+ <enum bitpos="9" extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_queue_family_foreign" number="127" type="device" author="EXT" requires="VK_KHR_external_memory" contact="Chad Versace @chadversary" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_QUEUE_FAMILY_FOREIGN_SPEC_VERSION"/>
+ <enum value=""VK_EXT_queue_family_foreign"" name="VK_EXT_QUEUE_FAMILY_FOREIGN_EXTENSION_NAME"/>
+ <enum name="VK_QUEUE_FAMILY_FOREIGN_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_dedicated_allocation" number="128" type="device" author="KHR" requires="VK_KHR_get_memory_requirements2" contact="James Jones @cubanismo" supported="vulkan">
+ <require>
+ <enum value="3" name="VK_KHR_DEDICATED_ALLOCATION_SPEC_VERSION"/>
+ <enum value=""VK_KHR_dedicated_allocation"" name="VK_KHR_DEDICATED_ALLOCATION_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS_KHR" alias="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO"/>
+ <type name="VkMemoryDedicatedRequirementsKHR"/>
+ <type name="VkMemoryDedicatedAllocateInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_debug_utils" number="129" type="instance" author="EXT" contact="Mark Young @MarkY_LunarG" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_DEBUG_UTILS_SPEC_VERSION"/>
+ <enum value=""VK_EXT_debug_utils"" name="VK_EXT_DEBUG_UTILS_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT"/>
+ <enum offset="4" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_DEBUG_UTILS_MESSENGER_EXT" comment="VkDebugUtilsMessengerEXT"/>
+ <type name="VkDebugUtilsObjectNameInfoEXT"/>
+ <type name="VkDebugUtilsObjectTagInfoEXT"/>
+ <type name="VkDebugUtilsLabelEXT"/>
+ <type name="VkDebugUtilsMessengerCallbackDataEXT"/>
+ <type name="VkDebugUtilsMessengerCreateInfoEXT"/>
+ <command name="vkSetDebugUtilsObjectNameEXT"/>
+ <command name="vkSetDebugUtilsObjectTagEXT"/>
+ <command name="vkQueueBeginDebugUtilsLabelEXT"/>
+ <command name="vkQueueEndDebugUtilsLabelEXT"/>
+ <command name="vkQueueInsertDebugUtilsLabelEXT"/>
+ <command name="vkCmdBeginDebugUtilsLabelEXT"/>
+ <command name="vkCmdEndDebugUtilsLabelEXT"/>
+ <command name="vkCmdInsertDebugUtilsLabelEXT"/>
+ <command name="vkCreateDebugUtilsMessengerEXT"/>
+ <command name="vkDestroyDebugUtilsMessengerEXT"/>
+ <command name="vkSubmitDebugUtilsMessageEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_ANDROID_external_memory_android_hardware_buffer" number="130" type="device" author="ANDROID" requires="VK_KHR_sampler_ycbcr_conversion,VK_KHR_external_memory,VK_EXT_queue_family_foreign" platform="android" contact="Jesse Hall @jessehall" supported="vulkan">
+ <require>
+ <enum value="3" name="VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_SPEC_VERSION"/>
+ <enum value=""VK_ANDROID_external_memory_android_hardware_buffer"" name="VK_ANDROID_EXTERNAL_MEMORY_ANDROID_HARDWARE_BUFFER_EXTENSION_NAME"/>
+ <enum bitpos="10" extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_USAGE_ANDROID"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_PROPERTIES_ANDROID"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_ANDROID_HARDWARE_BUFFER_FORMAT_PROPERTIES_ANDROID"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_ANDROID_HARDWARE_BUFFER_INFO_ANDROID"/>
+ <enum offset="4" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_GET_ANDROID_HARDWARE_BUFFER_INFO_ANDROID"/>
+ <enum offset="5" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_FORMAT_ANDROID"/>
+ <type name="VkAndroidHardwareBufferUsageANDROID"/>
+ <type name="VkAndroidHardwareBufferPropertiesANDROID"/>
+ <type name="VkAndroidHardwareBufferFormatPropertiesANDROID"/>
+ <type name="VkImportAndroidHardwareBufferInfoANDROID"/>
+ <type name="VkMemoryGetAndroidHardwareBufferInfoANDROID"/>
+ <type name="VkExternalFormatANDROID"/>
+ <command name="vkGetAndroidHardwareBufferPropertiesANDROID"/>
+ <command name="vkGetMemoryAndroidHardwareBufferANDROID"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_sampler_filter_minmax" number="131" type="device" author="NV" requires="VK_KHR_get_physical_device_properties2" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_SAMPLER_FILTER_MINMAX_SPEC_VERSION"/>
+ <enum value=""VK_EXT_sampler_filter_minmax"" name="VK_EXT_SAMPLER_FILTER_MINMAX_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT"/>
+ <enum bitpos="16" extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_MINMAX_BIT_EXT" comment="Format can be used with min/max reduction filtering"/>
+ <type name="VkSamplerReductionModeEXT"/>
+ <type name="VkSamplerReductionModeCreateInfoEXT"/>
+ <type name="VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_storage_buffer_storage_class" number="132" type="device" author="KHR" contact="Alexander Galazin @debater" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_STORAGE_BUFFER_STORAGE_CLASS_SPEC_VERSION"/>
+ <enum value=""VK_KHR_storage_buffer_storage_class"" name="VK_KHR_STORAGE_BUFFER_STORAGE_CLASS_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_gpu_shader_int16" number="133" type="device" author="AMD" contact="quentin.lin@amd.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_GPU_SHADER_INT16_SPEC_VERSION"/>
+ <enum value=""VK_AMD_gpu_shader_int16"" name="VK_AMD_GPU_SHADER_INT16_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_134" number="134" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_134_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_134"" name="VK_AMD_EXTENSION_134_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_135" number="135" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_135_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_135"" name="VK_AMD_EXTENSION_135_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_136" number="136" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_136_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_136"" name="VK_AMD_EXTENSION_136_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_mixed_attachment_samples" number="137" type="device" author="AMD" contact="Matthaeus G. Chajdas @anteru" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_MIXED_ATTACHMENT_SAMPLES_SPEC_VERSION"/>
+ <enum value=""VK_AMD_mixed_attachment_samples"" name="VK_AMD_MIXED_ATTACHMENT_SAMPLES_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_fragment_mask" number="138" author="AMD" contact="Aaron Hagan @ahagan" supported="vulkan" type="device">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_FRAGMENT_MASK_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_fragment_mask"" name="VK_AMD_SHADER_FRAGMENT_MASK_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_139" number="139" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_139_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_139"" name="VK_AMD_EXTENSION_139_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_140" number="140" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_140_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_140"" name="VK_AMD_EXTENSION_140_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_shader_stencil_export" number="141" type="device" author="EXT" contact="dominik.witczak@amd.com" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_SHADER_STENCIL_EXPORT_SPEC_VERSION"/>
+ <enum value=""VK_EXT_shader_stencil_export"" name="VK_EXT_SHADER_STENCIL_EXPORT_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_142" number="142" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_142_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_142"" name="VK_AMD_EXTENSION_142_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_143" number="143" author="AMD" contact="Mais Alnasser @malnasse" supported="disabled">
+ <require>
+ <enum value="0" name="VK_AMD_EXTENSION_143_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_143"" name="VK_AMD_EXTENSION_143_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_sample_locations" number="144" type="device" author="AMD" contact="Daniel Rakos @aqnuep" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_SAMPLE_LOCATIONS_SPEC_VERSION"/>
+ <enum value=""VK_EXT_sample_locations"" name="VK_EXT_SAMPLE_LOCATIONS_EXTENSION_NAME"/>
+ <enum bitpos="12" extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT"/>
+ <enum offset="4" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT"/>
+ <enum offset="0" extends="VkDynamicState" name="VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT"/>
+ <type name="VkSampleLocationEXT"/>
+ <type name="VkSampleLocationsInfoEXT"/>
+ <type name="VkAttachmentSampleLocationsEXT"/>
+ <type name="VkSubpassSampleLocationsEXT"/>
+ <type name="VkRenderPassSampleLocationsBeginInfoEXT"/>
+ <type name="VkPipelineSampleLocationsStateCreateInfoEXT"/>
+ <type name="VkPhysicalDeviceSampleLocationsPropertiesEXT"/>
+ <type name="VkMultisamplePropertiesEXT"/>
+ <command name="vkCmdSetSampleLocationsEXT"/>
+ <command name="vkGetPhysicalDeviceMultisamplePropertiesEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_relaxed_block_layout" number="145" type="device" author="KHR" contact="John Kessenich @johnk" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_RELAXED_BLOCK_LAYOUT_SPEC_VERSION"/>
+ <enum value=""VK_KHR_relaxed_block_layout"" name="VK_KHR_RELAXED_BLOCK_LAYOUT_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="RESERVED_DO_NOT_USE_146" number="146" supported="disabled" comment="Used for functionality subsumed into Vulkan 1.1 and not published as an extension">
+ </extension>
+ <extension name="VK_KHR_get_memory_requirements2" number="147" type="device" author="KHR" contact="Jason Ekstrand @jekstrand" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_GET_MEMORY_REQUIREMENTS_2_SPEC_VERSION"/>
+ <enum value=""VK_KHR_get_memory_requirements2"" name="VK_KHR_GET_MEMORY_REQUIREMENTS_2_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2_KHR" alias="VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2_KHR" alias="VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2_KHR" alias="VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2_KHR" alias="VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2_KHR" alias="VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2"/>
+ <type name="VkBufferMemoryRequirementsInfo2KHR"/>
+ <type name="VkImageMemoryRequirementsInfo2KHR"/>
+ <type name="VkImageSparseMemoryRequirementsInfo2KHR"/>
+ <type name="VkMemoryRequirements2KHR"/>
+ <type name="VkSparseImageMemoryRequirements2KHR"/>
+ <command name="vkGetImageMemoryRequirements2KHR"/>
+ <command name="vkGetBufferMemoryRequirements2KHR"/>
+ <command name="vkGetImageSparseMemoryRequirements2KHR"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_image_format_list" number="148" type="device" author="KHR" contact="Jason Ekstrand @jekstrand" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_IMAGE_FORMAT_LIST_SPEC_VERSION"/>
+ <enum value=""VK_KHR_image_format_list"" name="VK_KHR_IMAGE_FORMAT_LIST_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR"/>
+ <type name="VkImageFormatListCreateInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_blend_operation_advanced" number="149" type="device" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="2" name="VK_EXT_BLEND_OPERATION_ADVANCED_SPEC_VERSION"/>
+ <enum value=""VK_EXT_blend_operation_advanced"" name="VK_EXT_BLEND_OPERATION_ADVANCED_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT"/>
+ <type name="VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT"/>
+ <type name="VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT"/>
+ <type name="VkPipelineColorBlendAdvancedStateCreateInfoEXT"/>
+ <type name="VkBlendOverlapEXT"/>
+ <enum offset="0" extends="VkBlendOp" name="VK_BLEND_OP_ZERO_EXT"/>
+ <enum offset="1" extends="VkBlendOp" name="VK_BLEND_OP_SRC_EXT"/>
+ <enum offset="2" extends="VkBlendOp" name="VK_BLEND_OP_DST_EXT"/>
+ <enum offset="3" extends="VkBlendOp" name="VK_BLEND_OP_SRC_OVER_EXT"/>
+ <enum offset="4" extends="VkBlendOp" name="VK_BLEND_OP_DST_OVER_EXT"/>
+ <enum offset="5" extends="VkBlendOp" name="VK_BLEND_OP_SRC_IN_EXT"/>
+ <enum offset="6" extends="VkBlendOp" name="VK_BLEND_OP_DST_IN_EXT"/>
+ <enum offset="7" extends="VkBlendOp" name="VK_BLEND_OP_SRC_OUT_EXT"/>
+ <enum offset="8" extends="VkBlendOp" name="VK_BLEND_OP_DST_OUT_EXT"/>
+ <enum offset="9" extends="VkBlendOp" name="VK_BLEND_OP_SRC_ATOP_EXT"/>
+ <enum offset="10" extends="VkBlendOp" name="VK_BLEND_OP_DST_ATOP_EXT"/>
+ <enum offset="11" extends="VkBlendOp" name="VK_BLEND_OP_XOR_EXT"/>
+ <enum offset="12" extends="VkBlendOp" name="VK_BLEND_OP_MULTIPLY_EXT"/>
+ <enum offset="13" extends="VkBlendOp" name="VK_BLEND_OP_SCREEN_EXT"/>
+ <enum offset="14" extends="VkBlendOp" name="VK_BLEND_OP_OVERLAY_EXT"/>
+ <enum offset="15" extends="VkBlendOp" name="VK_BLEND_OP_DARKEN_EXT"/>
+ <enum offset="16" extends="VkBlendOp" name="VK_BLEND_OP_LIGHTEN_EXT"/>
+ <enum offset="17" extends="VkBlendOp" name="VK_BLEND_OP_COLORDODGE_EXT"/>
+ <enum offset="18" extends="VkBlendOp" name="VK_BLEND_OP_COLORBURN_EXT"/>
+ <enum offset="19" extends="VkBlendOp" name="VK_BLEND_OP_HARDLIGHT_EXT"/>
+ <enum offset="20" extends="VkBlendOp" name="VK_BLEND_OP_SOFTLIGHT_EXT"/>
+ <enum offset="21" extends="VkBlendOp" name="VK_BLEND_OP_DIFFERENCE_EXT"/>
+ <enum offset="22" extends="VkBlendOp" name="VK_BLEND_OP_EXCLUSION_EXT"/>
+ <enum offset="23" extends="VkBlendOp" name="VK_BLEND_OP_INVERT_EXT"/>
+ <enum offset="24" extends="VkBlendOp" name="VK_BLEND_OP_INVERT_RGB_EXT"/>
+ <enum offset="25" extends="VkBlendOp" name="VK_BLEND_OP_LINEARDODGE_EXT"/>
+ <enum offset="26" extends="VkBlendOp" name="VK_BLEND_OP_LINEARBURN_EXT"/>
+ <enum offset="27" extends="VkBlendOp" name="VK_BLEND_OP_VIVIDLIGHT_EXT"/>
+ <enum offset="28" extends="VkBlendOp" name="VK_BLEND_OP_LINEARLIGHT_EXT"/>
+ <enum offset="29" extends="VkBlendOp" name="VK_BLEND_OP_PINLIGHT_EXT"/>
+ <enum offset="30" extends="VkBlendOp" name="VK_BLEND_OP_HARDMIX_EXT"/>
+ <enum offset="31" extends="VkBlendOp" name="VK_BLEND_OP_HSL_HUE_EXT"/>
+ <enum offset="32" extends="VkBlendOp" name="VK_BLEND_OP_HSL_SATURATION_EXT"/>
+ <enum offset="33" extends="VkBlendOp" name="VK_BLEND_OP_HSL_COLOR_EXT"/>
+ <enum offset="34" extends="VkBlendOp" name="VK_BLEND_OP_HSL_LUMINOSITY_EXT"/>
+ <enum offset="35" extends="VkBlendOp" name="VK_BLEND_OP_PLUS_EXT"/>
+ <enum offset="36" extends="VkBlendOp" name="VK_BLEND_OP_PLUS_CLAMPED_EXT"/>
+ <enum offset="37" extends="VkBlendOp" name="VK_BLEND_OP_PLUS_CLAMPED_ALPHA_EXT"/>
+ <enum offset="38" extends="VkBlendOp" name="VK_BLEND_OP_PLUS_DARKER_EXT"/>
+ <enum offset="39" extends="VkBlendOp" name="VK_BLEND_OP_MINUS_EXT"/>
+ <enum offset="40" extends="VkBlendOp" name="VK_BLEND_OP_MINUS_CLAMPED_EXT"/>
+ <enum offset="41" extends="VkBlendOp" name="VK_BLEND_OP_CONTRAST_EXT"/>
+ <enum offset="42" extends="VkBlendOp" name="VK_BLEND_OP_INVERT_OVG_EXT"/>
+ <enum offset="43" extends="VkBlendOp" name="VK_BLEND_OP_RED_EXT"/>
+ <enum offset="44" extends="VkBlendOp" name="VK_BLEND_OP_GREEN_EXT"/>
+ <enum offset="45" extends="VkBlendOp" name="VK_BLEND_OP_BLUE_EXT"/>
+ <enum bitpos="19" extends="VkAccessFlagBits" name="VK_ACCESS_COLOR_ATTACHMENT_READ_NONCOHERENT_BIT_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_fragment_coverage_to_color" number="150" type="device" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_FRAGMENT_COVERAGE_TO_COLOR_SPEC_VERSION"/>
+ <enum value=""VK_NV_fragment_coverage_to_color"" name="VK_NV_FRAGMENT_COVERAGE_TO_COLOR_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV"/>
+ <type name="VkPipelineCoverageToColorStateCreateFlagsNV"/>
+ <type name="VkPipelineCoverageToColorStateCreateInfoNV"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_151" number="151" author="NV" contact="Jeff Bolz @jbolz" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_151_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_151"" name="VK_NV_EXTENSION_151_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_152" number="152" author="NV" contact="Jeff Bolz @jbolz" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_152_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_152"" name="VK_NV_EXTENSION_152_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_framebuffer_mixed_samples" number="153" type="device" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_FRAMEBUFFER_MIXED_SAMPLES_SPEC_VERSION"/>
+ <enum value=""VK_NV_framebuffer_mixed_samples"" name="VK_NV_FRAMEBUFFER_MIXED_SAMPLES_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV"/>
+ <type name="VkPipelineCoverageModulationStateCreateInfoNV"/>
+ <type name="VkPipelineCoverageModulationStateCreateFlagsNV"/>
+ <type name="VkCoverageModulationModeNV"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_fill_rectangle" number="154" type="device" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_FILL_RECTANGLE_SPEC_VERSION"/>
+ <enum value=""VK_NV_fill_rectangle"" name="VK_NV_FILL_RECTANGLE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkPolygonMode" name="VK_POLYGON_MODE_FILL_RECTANGLE_NV"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_155" number="155" author="NV" contact="Jeff Bolz @jbolz" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_155_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_155"" name="VK_NV_EXTENSION_155_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_post_depth_coverage" number="156" type="device" author="NV" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_POST_DEPTH_COVERAGE_SPEC_VERSION"/>
+ <enum value=""VK_EXT_post_depth_coverage"" name="VK_EXT_POST_DEPTH_COVERAGE_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_sampler_ycbcr_conversion" number="157" type="device" requires="VK_KHR_maintenance1,VK_KHR_bind_memory2,VK_KHR_get_memory_requirements2,VK_KHR_get_physical_device_properties2" author="KHR" contact="Andrew Garrard @fluppeteer" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_SAMPLER_YCBCR_CONVERSION_SPEC_VERSION"/>
+ <enum value=""VK_KHR_sampler_ycbcr_conversion"" name="VK_KHR_SAMPLER_YCBCR_CONVERSION_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO_KHR" alias="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO_KHR" alias="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO_KHR" alias="VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO_KHR" alias="VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES"/>
+ <enum extends="VkDebugReportObjectTypeEXT" name="VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_KHR_EXT" alias="VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT"/>
+ <enum extends="VkObjectType" name="VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_KHR" alias="VK_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G8B8G8R8_422_UNORM_KHR" alias="VK_FORMAT_G8B8G8R8_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_B8G8R8G8_422_UNORM_KHR" alias="VK_FORMAT_B8G8R8G8_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM_KHR" alias="VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G8_B8R8_2PLANE_420_UNORM_KHR" alias="VK_FORMAT_G8_B8R8_2PLANE_420_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM_KHR" alias="VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G8_B8R8_2PLANE_422_UNORM_KHR" alias="VK_FORMAT_G8_B8R8_2PLANE_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM_KHR" alias="VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_R10X6_UNORM_PACK16_KHR" alias="VK_FORMAT_R10X6_UNORM_PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_R10X6G10X6_UNORM_2PACK16_KHR" alias="VK_FORMAT_R10X6G10X6_UNORM_2PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16_KHR" alias="VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16_KHR" alias="VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16_KHR" alias="VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16_KHR" alias="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16_KHR" alias="VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16_KHR" alias="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16_KHR" alias="VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16_KHR" alias="VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_R12X4_UNORM_PACK16_KHR" alias="VK_FORMAT_R12X4_UNORM_PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_R12X4G12X4_UNORM_2PACK16_KHR" alias="VK_FORMAT_R12X4G12X4_UNORM_2PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16_KHR" alias="VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16_KHR" alias="VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16_KHR" alias="VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16_KHR" alias="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16_KHR" alias="VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16_KHR" alias="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16_KHR" alias="VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16_KHR" alias="VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G16B16G16R16_422_UNORM_KHR" alias="VK_FORMAT_G16B16G16R16_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_B16G16R16G16_422_UNORM_KHR" alias="VK_FORMAT_B16G16R16G16_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM_KHR" alias="VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G16_B16R16_2PLANE_420_UNORM_KHR" alias="VK_FORMAT_G16_B16R16_2PLANE_420_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM_KHR" alias="VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G16_B16R16_2PLANE_422_UNORM_KHR" alias="VK_FORMAT_G16_B16R16_2PLANE_422_UNORM"/>
+ <enum extends="VkFormat" name="VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM_KHR" alias="VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM"/>
+ <enum extends="VkImageAspectFlagBits" name="VK_IMAGE_ASPECT_PLANE_0_BIT_KHR" alias="VK_IMAGE_ASPECT_PLANE_0_BIT"/>
+ <enum extends="VkImageAspectFlagBits" name="VK_IMAGE_ASPECT_PLANE_1_BIT_KHR" alias="VK_IMAGE_ASPECT_PLANE_1_BIT"/>
+ <enum extends="VkImageAspectFlagBits" name="VK_IMAGE_ASPECT_PLANE_2_BIT_KHR" alias="VK_IMAGE_ASPECT_PLANE_2_BIT"/>
+ <enum extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_DISJOINT_BIT_KHR" alias="VK_IMAGE_CREATE_DISJOINT_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT_KHR" alias="VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT_KHR" alias="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT_KHR" alias="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT_KHR" alias="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT_KHR" alias="VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_DISJOINT_BIT_KHR" alias="VK_FORMAT_FEATURE_DISJOINT_BIT"/>
+ <enum extends="VkFormatFeatureFlagBits" name="VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT_KHR" alias="VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT"/>
+ <type name="VkSamplerYcbcrConversionCreateInfoKHR"/>
+ <type name="VkSamplerYcbcrConversionInfoKHR"/>
+ <type name="VkBindImagePlaneMemoryInfoKHR"/>
+ <type name="VkImagePlaneMemoryRequirementsInfoKHR"/>
+ <type name="VkPhysicalDeviceSamplerYcbcrConversionFeaturesKHR"/>
+ <type name="VkSamplerYcbcrConversionImageFormatPropertiesKHR"/>
+ <command name="vkCreateSamplerYcbcrConversionKHR"/>
+ <command name="vkDestroySamplerYcbcrConversionKHR"/>
+ <type name="VkSamplerYcbcrConversionKHR"/>
+ <type name="VkSamplerYcbcrModelConversionKHR"/>
+ <enum extends="VkSamplerYcbcrModelConversion" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY_KHR" alias="VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY"/>
+ <enum extends="VkSamplerYcbcrModelConversion" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY_KHR" alias="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY"/>
+ <enum extends="VkSamplerYcbcrModelConversion" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709_KHR" alias="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709"/>
+ <enum extends="VkSamplerYcbcrModelConversion" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601_KHR" alias="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601"/>
+ <enum extends="VkSamplerYcbcrModelConversion" name="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020_KHR" alias="VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020"/>
+ <type name="VkSamplerYcbcrRangeKHR"/>
+ <enum extends="VkSamplerYcbcrRange" name="VK_SAMPLER_YCBCR_RANGE_ITU_FULL_KHR" alias="VK_SAMPLER_YCBCR_RANGE_ITU_FULL"/>
+ <enum extends="VkSamplerYcbcrRange" name="VK_SAMPLER_YCBCR_RANGE_ITU_NARROW_KHR" alias="VK_SAMPLER_YCBCR_RANGE_ITU_NARROW"/>
+ <type name="VkChromaLocationKHR"/>
+ <enum extends="VkChromaLocation" name="VK_CHROMA_LOCATION_COSITED_EVEN_KHR" alias="VK_CHROMA_LOCATION_COSITED_EVEN"/>
+ <enum extends="VkChromaLocation" name="VK_CHROMA_LOCATION_MIDPOINT_KHR" alias="VK_CHROMA_LOCATION_MIDPOINT"/>
+ </require>
+ <require extension="VK_EXT_debug_report">
+ <enum extends="VkDebugReportObjectTypeEXT" offset="0" name="VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_YCBCR_CONVERSION_EXT"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_bind_memory2" number="158" type="device" author="KHR" contact="Tobias Hector @tobias" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_BIND_MEMORY_2_SPEC_VERSION"/>
+ <enum value=""VK_KHR_bind_memory2"" name="VK_KHR_BIND_MEMORY_2_EXTENSION_NAME"/>
+ <command name="vkBindBufferMemory2KHR"/>
+ <command name="vkBindImageMemory2KHR"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO_KHR" alias="VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO_KHR" alias="VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO"/>
+ <enum extends="VkImageCreateFlagBits" name="VK_IMAGE_CREATE_ALIAS_BIT_KHR" alias="VK_IMAGE_CREATE_ALIAS_BIT"/>
+ <type name="VkBindBufferMemoryInfoKHR"/>
+ <type name="VkBindImageMemoryInfoKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_159" number="159" author="EXT" contact="Chad Versace @chadversary" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_159_SPEC_VERSION"/>
+ <enum value=""VK_EXT_extension_159"" name="VK_EXT_EXTENSION_159_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_160" number="160" author="EXT" contact="Mark Young @MarkY_LunarG" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_160_SPEC_VERSION"/>
+ <enum value=""VK_EXT_extension_160"" name="VK_EXT_EXTENSION_160_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_validation_cache" number="161" type="device" author="GOOGLE" contact="Cort Stratton @cdwfs" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_VALIDATION_CACHE_SPEC_VERSION"/>
+ <enum value=""VK_EXT_validation_cache"" name="VK_EXT_VALIDATION_CACHE_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT"/>
+ <enum offset="0" extends="VkObjectType" name="VK_OBJECT_TYPE_VALIDATION_CACHE_EXT" comment="VkValidationCacheEXT"/>
+ <enum value="VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT_EXT" name="VK_DEBUG_REPORT_OBJECT_TYPE_VALIDATION_CACHE_EXT"/>
+ <type name="VkValidationCacheEXT"/>
+ <type name="VkValidationCacheCreateInfoEXT"/>
+ <type name="VkShaderModuleValidationCacheCreateInfoEXT"/>
+ <type name="VkValidationCacheHeaderVersionEXT"/>
+ <type name="VkValidationCacheCreateFlagsEXT"/>
+ <command name="vkCreateValidationCacheEXT"/>
+ <command name="vkDestroyValidationCacheEXT"/>
+ <command name="vkMergeValidationCachesEXT"/>
+ <command name="vkGetValidationCacheDataEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_descriptor_indexing" number="162" type="device" requires="VK_KHR_get_physical_device_properties2,VK_KHR_maintenance3" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="2" name="VK_EXT_DESCRIPTOR_INDEXING_SPEC_VERSION"/>
+ <enum value=""VK_EXT_descriptor_indexing"" name="VK_EXT_DESCRIPTOR_INDEXING_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_BINDING_FLAGS_CREATE_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_FEATURES_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_PROPERTIES_EXT"/>
+ <enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_ALLOCATE_INFO_EXT"/>
+ <enum offset="4" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_LAYOUT_SUPPORT_EXT"/>
+ <enum bitpos="1" extends="VkDescriptorPoolCreateFlagBits" name="VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT"/>
+ <enum bitpos="1" extends="VkDescriptorSetLayoutCreateFlagBits" name="VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT"/>
+ <enum offset="0" dir="-" extends="VkResult" name="VK_ERROR_FRAGMENTATION_EXT"/>
+ <type name="VkDescriptorSetLayoutBindingFlagsCreateInfoEXT"/>
+ <type name="VkPhysicalDeviceDescriptorIndexingFeaturesEXT"/>
+ <type name="VkPhysicalDeviceDescriptorIndexingPropertiesEXT"/>
+ <type name="VkDescriptorSetVariableDescriptorCountAllocateInfoEXT"/>
+ <type name="VkDescriptorSetVariableDescriptorCountLayoutSupportEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_shader_viewport_index_layer" number="163" type="device" author="NV" contact="Daniel Koch @dgkoch" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_SHADER_VIEWPORT_INDEX_LAYER_SPEC_VERSION"/>
+ <enum value=""VK_EXT_shader_viewport_index_layer"" name="VK_EXT_SHADER_VIEWPORT_INDEX_LAYER_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_164" number="164" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_164_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_164"" name="VK_EXT_EXTENSION_164_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_165" number="165" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_165_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_165"" name="VK_EXT_EXTENSION_165_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_166" number="166" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_166_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_166"" name="VK_EXT_EXTENSION_166_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_167" number="167" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_167_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_167"" name="VK_EXT_EXTENSION_167_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_168" number="168" author="NV" contact="Daniel Koch @dgkoch" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_168_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_168"" name="VK_EXT_EXTENSION_168_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_maintenance3" number="169" type="device" requires="VK_KHR_get_physical_device_properties2" author="KHR" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_KHR_MAINTENANCE3_SPEC_VERSION"/>
+ <enum value=""VK_KHR_maintenance3"" name="VK_KHR_MAINTENANCE3_EXTENSION_NAME"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES_KHR" alias="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES"/>
+ <enum extends="VkStructureType" name="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT_KHR" alias="VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT"/>
+ <type name="VkPhysicalDeviceMaintenance3PropertiesKHR"/>
+ <type name="VkDescriptorSetLayoutSupportKHR"/>
+ <command name="vkGetDescriptorSetLayoutSupportKHR"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_170" number="170" author="NV" contact="Piers Daniell @pdaniell" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_170_SPEC_VERSION"/>
+ <enum value=""VK_EXT_extension_170"" name="VK_EXT_EXTENSION_170_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_QCOM_extension_171" number="171" author="QCOM" contact="Bill Licea-Kane @billl" supported="disabled">
+ <require>
+ <enum value="0" name="VK_QCOM_extension_171_SPEC_VERSION"/>
+ <enum value=""VK_QCOM_extension_171"" name="VK_QCOM_extension_171_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_QCOM_extension_172" number="172" author="QCOM" contact="Bill Licea-Kane @billl" supported="disabled">
+ <require>
+ <enum value="0" name="VK_QCOM_extension_172_SPEC_VERSION"/>
+ <enum value=""VK_QCOM_extension_172"" name="VK_QCOM_extension_172_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_QCOM_extension_173" number="173" author="QCOM" contact="Bill Licea-Kane @billl" supported="disabled">
+ <require>
+ <enum value="0" name="VK_QCOM_extension_173_SPEC_VERSION"/>
+ <enum value=""VK_QCOM_extension_173"" name="VK_QCOM_extension_173_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_QCOM_extension_174" number="174" author="QCOM" contact="Bill Licea-Kane @billl" supported="disabled">
+ <require>
+ <enum value="0" name="VK_QCOM_extension_174_SPEC_VERSION"/>
+ <enum value=""VK_QCOM_extension_174"" name="VK_QCOM_extension_174_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_global_priority" number="175" type="device" author="EXT" contact="Andres Rodriguez @lostgoat" supported="vulkan">
+ <require>
+ <enum value="2" name="VK_EXT_GLOBAL_PRIORITY_SPEC_VERSION"/>
+ <enum value=""VK_EXT_global_priority"" name="VK_EXT_GLOBAL_PRIORITY_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT"/>
+ <enum offset="1" dir="-" extends="VkResult" name="VK_ERROR_NOT_PERMITTED_EXT"/>
+ <type name="VkDeviceQueueGlobalPriorityCreateInfoEXT"/>
+ <type name="VkQueueGlobalPriorityEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_176" number="176" author="EXT" contact="Neil Henning @neil_henning" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_176_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_176"" name="VK_KHR_EXTENSION_176_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_177" number="177" author="EXT" contact="Neil Henning @neil_henning" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_177_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_177"" name="VK_KHR_EXTENSION_177_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_178" number="178" author="EXT" contact="Alexander Galazin @debater" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_178_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_178"" name="VK_KHR_EXTENSION_178_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_external_memory_host" number="179" type="device" author="EXT" requires="VK_KHR_external_memory" contact="Daniel Rakos @aqnuep" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION"/>
+ <enum value=""VK_EXT_external_memory_host"" name="VK_EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT"/>
+ <enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT"/>
+ <enum bitpos="7" extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT"/>
+ <enum bitpos="8" extends="VkExternalMemoryHandleTypeFlagBits" name="VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT"/>
+ <type name="VkExternalMemoryHandleTypeFlagsKHR"/>
+ <type name="VkExternalMemoryHandleTypeFlagBitsKHR"/>
+ <type name="VkImportMemoryHostPointerInfoEXT"/>
+ <type name="VkMemoryHostPointerPropertiesEXT"/>
+ <type name="VkPhysicalDeviceExternalMemoryHostPropertiesEXT"/>
+ <command name="vkGetMemoryHostPointerPropertiesEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_buffer_marker" number="180" type="device" author="AMD" contact="Daniel Rakos @aqnuep" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_BUFFER_MARKER_SPEC_VERSION"/>
+ <enum value=""VK_AMD_buffer_marker"" name="VK_AMD_BUFFER_MARKER_EXTENSION_NAME"/>
+ <command name="vkCmdWriteBufferMarkerAMD"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_181" number="181" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_181_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_181"" name="VK_KHR_EXTENSION_181_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_182" number="182" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_182_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_182"" name="VK_KHR_EXTENSION_182_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_183" number="183" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_183_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_183"" name="VK_KHR_EXTENSION_183_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_184" number="184" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_184_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_184"" name="VK_KHR_EXTENSION_184_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_185" number="185" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_185_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_185"" name="VK_KHR_EXTENSION_185_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_shader_core_properties" number="186" type="device" author="AMD" requires="VK_KHR_get_physical_device_properties2" contact="Martin Dinkov @mdinkov" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_AMD_SHADER_CORE_PROPERTIES_SPEC_VERSION"/>
+ <enum value=""VK_AMD_shader_core_properties"" name="VK_AMD_SHADER_CORE_PROPERTIES_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_CORE_PROPERTIES_AMD"/>
+ <type name="VkPhysicalDeviceShaderCorePropertiesAMD"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_187" number="187" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_187_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_187"" name="VK_KHR_EXTENSION_187_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_188" number="188" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_188_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_188"" name="VK_KHR_EXTENSION_188_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_189" number="189" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_189_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_189"" name="VK_KHR_EXTENSION_189_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_AMD_extension_190" number="190" author="AMD" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_190_SPEC_VERSION"/>
+ <enum value=""VK_AMD_extension_190"" name="VK_KHR_EXTENSION_190_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_vertex_attribute_divisor" number="191" type="device" requires="VK_KHR_get_physical_device_properties2" author="NV" contact="Vikram Kushwaha @vkushwaha" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_EXT_VERTEX_ATTRIBUTE_DIVISOR_SPEC_VERSION"/>
+ <enum value=""VK_EXT_vertex_attribute_divisor"" name="VK_EXT_VERTEX_ATTRIBUTE_DIVISOR_EXTENSION_NAME"/>
+ <enum offset="0" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT"/>
+ <enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT"/>
+ <type name="VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT"/>
+ <type name="VkVertexInputBindingDivisorDescriptionEXT"/>
+ <type name="VkPipelineVertexInputDivisorStateCreateInfoEXT"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_192" number="192" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_192_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_192"" name="VK_GOOGLE_EXTENSION_192_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_193" number="193" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_193_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_193"" name="VK_GOOGLE_EXTENSION_193_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_194" number="194" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_194_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_194"" name="VK_GOOGLE_EXTENSION_194_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_195" number="195" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_195_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_195"" name="VK_GOOGLE_EXTENSION_195_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_GOOGLE_extension_196" number="196" author="GOOGLE" contact="Jean-Francois Roy @jfroy" supported="disabled">
+ <require>
+ <enum value="0" name="VK_GOOGLE_EXTENSION_196_SPEC_VERSION"/>
+ <enum value=""VK_GOOGLE_extension_196"" name="VK_GOOGLE_EXTENSION_196_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_EXT_extension_197" number="197" author="Baldur Karlsson" contact="baldurk@baldurk.org" supported="disabled">
+ <require>
+ <enum value="0" name="VK_EXT_EXTENSION_197_SPEC_VERSION"/>
+ <enum value=""VK_EXT_extension_197"" name="VK_EXT_EXTENSION_197_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_ARM_extension_198" number="198" author="Alexander Galazin" contact="@debater" supported="disabled">
+ <require>
+ <enum value="0" name="VK_ARM_EXTENSION_198_SPEC_VERSION"/>
+ <enum value=""VK_EXT_extension_198"" name="VK_ARM_EXTENSION_198_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_shader_subgroup_partitioned" number="199" type="device" requiresCore="1.1" author="NV" contact="Jeff Bolz @jbolz" supported="vulkan">
+ <require>
+ <enum value="1" name="VK_NV_SHADER_SUBGROUP_PARTITIONED_SPEC_VERSION"/>
+ <enum value=""VK_NV_shader_subgroup_partitioned"" name="VK_NV_SHADER_SUBGROUP_PARTITIONED_EXTENSION_NAME"/>
+ <enum bitpos="8" extends="VkSubgroupFeatureFlagBits" name="VK_SUBGROUP_FEATURE_PARTITIONED_BIT_NV"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_200" number="200" author="KHR" contact="Jan-Harald Fredriksen @janharald" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_200_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_200"" name="VK_KHR_EXTENSION_200_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_201" number="201" type="device" author="KHR" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_201_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_201"" name="VK_KHR_EXTENSION_201_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_202" number="202" author="NV" contact="Pat Brown @pbrown" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_202_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_202"" name="VK_NV_EXTENSION_202_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_203" number="203" author="NV" contact="Pat Brown @pbrown" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_203_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_203"" name="VK_NV_EXTENSION_203_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_204" number="204" author="NV" contact="Pat Brown @pbrown" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_204_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_204"" name="VK_NV_EXTENSION_204_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_205" number="205" author="NV" contact="Pat Brown @pbrown" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_205_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_205"" name="VK_NV_EXTENSION_205_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_206" number="206" author="NV" contact="Pat Brown @pbrown" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_206_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_206"" name="VK_NV_EXTENSION_206_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_NV_extension_207" number="207" author="NV" contact="Nuno Subtil @nsubtil" supported="disabled">
+ <require>
+ <enum value="0" name="VK_NV_EXTENSION_207_SPEC_VERSION"/>
+ <enum value=""VK_NV_extension_207"" name="VK_NV_EXTENSION_207_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ <extension name="VK_KHR_extension_208" number="208" type="device" author="KHR" contact="Daniel Rakos @aqnuep" supported="disabled">
+ <require>
+ <enum value="0" name="VK_KHR_EXTENSION_208_SPEC_VERSION"/>
+ <enum value=""VK_KHR_extension_208"" name="VK_KHR_EXTENSION_208_EXTENSION_NAME"/>
+ </require>
+ </extension>
+ </extensions>
+</registry>