vulkan_fuchsia.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. #ifndef VULKAN_FUCHSIA_H_
  2. #define VULKAN_FUCHSIA_H_ 1
  3. /*
  4. ** Copyright 2015-2023 The Khronos Group Inc.
  5. **
  6. ** SPDX-License-Identifier: Apache-2.0
  7. */
  8. /*
  9. ** This header is generated from the Khronos Vulkan XML API Registry.
  10. **
  11. */
  12. #ifdef __cplusplus
  13. extern "C" {
  14. #endif
  15. // VK_FUCHSIA_imagepipe_surface is a preprocessor guard. Do not pass it to API calls.
  16. #define VK_FUCHSIA_imagepipe_surface 1
  17. #define VK_FUCHSIA_IMAGEPIPE_SURFACE_SPEC_VERSION 1
  18. #define VK_FUCHSIA_IMAGEPIPE_SURFACE_EXTENSION_NAME "VK_FUCHSIA_imagepipe_surface"
  19. typedef VkFlags VkImagePipeSurfaceCreateFlagsFUCHSIA;
  20. typedef struct VkImagePipeSurfaceCreateInfoFUCHSIA {
  21. VkStructureType sType;
  22. const void* pNext;
  23. VkImagePipeSurfaceCreateFlagsFUCHSIA flags;
  24. zx_handle_t imagePipeHandle;
  25. } VkImagePipeSurfaceCreateInfoFUCHSIA;
  26. typedef VkResult (VKAPI_PTR *PFN_vkCreateImagePipeSurfaceFUCHSIA)(VkInstance instance, const VkImagePipeSurfaceCreateInfoFUCHSIA* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
  27. #ifndef VK_NO_PROTOTYPES
  28. VKAPI_ATTR VkResult VKAPI_CALL vkCreateImagePipeSurfaceFUCHSIA(
  29. VkInstance instance,
  30. const VkImagePipeSurfaceCreateInfoFUCHSIA* pCreateInfo,
  31. const VkAllocationCallbacks* pAllocator,
  32. VkSurfaceKHR* pSurface);
  33. #endif
  34. // VK_FUCHSIA_external_memory is a preprocessor guard. Do not pass it to API calls.
  35. #define VK_FUCHSIA_external_memory 1
  36. #define VK_FUCHSIA_EXTERNAL_MEMORY_SPEC_VERSION 1
  37. #define VK_FUCHSIA_EXTERNAL_MEMORY_EXTENSION_NAME "VK_FUCHSIA_external_memory"
  38. typedef struct VkImportMemoryZirconHandleInfoFUCHSIA {
  39. VkStructureType sType;
  40. const void* pNext;
  41. VkExternalMemoryHandleTypeFlagBits handleType;
  42. zx_handle_t handle;
  43. } VkImportMemoryZirconHandleInfoFUCHSIA;
  44. typedef struct VkMemoryZirconHandlePropertiesFUCHSIA {
  45. VkStructureType sType;
  46. void* pNext;
  47. uint32_t memoryTypeBits;
  48. } VkMemoryZirconHandlePropertiesFUCHSIA;
  49. typedef struct VkMemoryGetZirconHandleInfoFUCHSIA {
  50. VkStructureType sType;
  51. const void* pNext;
  52. VkDeviceMemory memory;
  53. VkExternalMemoryHandleTypeFlagBits handleType;
  54. } VkMemoryGetZirconHandleInfoFUCHSIA;
  55. typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryZirconHandleFUCHSIA)(VkDevice device, const VkMemoryGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo, zx_handle_t* pZirconHandle);
  56. typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryZirconHandlePropertiesFUCHSIA)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, zx_handle_t zirconHandle, VkMemoryZirconHandlePropertiesFUCHSIA* pMemoryZirconHandleProperties);
  57. #ifndef VK_NO_PROTOTYPES
  58. VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryZirconHandleFUCHSIA(
  59. VkDevice device,
  60. const VkMemoryGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo,
  61. zx_handle_t* pZirconHandle);
  62. VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryZirconHandlePropertiesFUCHSIA(
  63. VkDevice device,
  64. VkExternalMemoryHandleTypeFlagBits handleType,
  65. zx_handle_t zirconHandle,
  66. VkMemoryZirconHandlePropertiesFUCHSIA* pMemoryZirconHandleProperties);
  67. #endif
  68. // VK_FUCHSIA_external_semaphore is a preprocessor guard. Do not pass it to API calls.
  69. #define VK_FUCHSIA_external_semaphore 1
  70. #define VK_FUCHSIA_EXTERNAL_SEMAPHORE_SPEC_VERSION 1
  71. #define VK_FUCHSIA_EXTERNAL_SEMAPHORE_EXTENSION_NAME "VK_FUCHSIA_external_semaphore"
  72. typedef struct VkImportSemaphoreZirconHandleInfoFUCHSIA {
  73. VkStructureType sType;
  74. const void* pNext;
  75. VkSemaphore semaphore;
  76. VkSemaphoreImportFlags flags;
  77. VkExternalSemaphoreHandleTypeFlagBits handleType;
  78. zx_handle_t zirconHandle;
  79. } VkImportSemaphoreZirconHandleInfoFUCHSIA;
  80. typedef struct VkSemaphoreGetZirconHandleInfoFUCHSIA {
  81. VkStructureType sType;
  82. const void* pNext;
  83. VkSemaphore semaphore;
  84. VkExternalSemaphoreHandleTypeFlagBits handleType;
  85. } VkSemaphoreGetZirconHandleInfoFUCHSIA;
  86. typedef VkResult (VKAPI_PTR *PFN_vkImportSemaphoreZirconHandleFUCHSIA)(VkDevice device, const VkImportSemaphoreZirconHandleInfoFUCHSIA* pImportSemaphoreZirconHandleInfo);
  87. typedef VkResult (VKAPI_PTR *PFN_vkGetSemaphoreZirconHandleFUCHSIA)(VkDevice device, const VkSemaphoreGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo, zx_handle_t* pZirconHandle);
  88. #ifndef VK_NO_PROTOTYPES
  89. VKAPI_ATTR VkResult VKAPI_CALL vkImportSemaphoreZirconHandleFUCHSIA(
  90. VkDevice device,
  91. const VkImportSemaphoreZirconHandleInfoFUCHSIA* pImportSemaphoreZirconHandleInfo);
  92. VKAPI_ATTR VkResult VKAPI_CALL vkGetSemaphoreZirconHandleFUCHSIA(
  93. VkDevice device,
  94. const VkSemaphoreGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo,
  95. zx_handle_t* pZirconHandle);
  96. #endif
  97. // VK_FUCHSIA_buffer_collection is a preprocessor guard. Do not pass it to API calls.
  98. #define VK_FUCHSIA_buffer_collection 1
  99. VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkBufferCollectionFUCHSIA)
  100. #define VK_FUCHSIA_BUFFER_COLLECTION_SPEC_VERSION 2
  101. #define VK_FUCHSIA_BUFFER_COLLECTION_EXTENSION_NAME "VK_FUCHSIA_buffer_collection"
  102. typedef VkFlags VkImageFormatConstraintsFlagsFUCHSIA;
  103. typedef enum VkImageConstraintsInfoFlagBitsFUCHSIA {
  104. VK_IMAGE_CONSTRAINTS_INFO_CPU_READ_RARELY_FUCHSIA = 0x00000001,
  105. VK_IMAGE_CONSTRAINTS_INFO_CPU_READ_OFTEN_FUCHSIA = 0x00000002,
  106. VK_IMAGE_CONSTRAINTS_INFO_CPU_WRITE_RARELY_FUCHSIA = 0x00000004,
  107. VK_IMAGE_CONSTRAINTS_INFO_CPU_WRITE_OFTEN_FUCHSIA = 0x00000008,
  108. VK_IMAGE_CONSTRAINTS_INFO_PROTECTED_OPTIONAL_FUCHSIA = 0x00000010,
  109. VK_IMAGE_CONSTRAINTS_INFO_FLAG_BITS_MAX_ENUM_FUCHSIA = 0x7FFFFFFF
  110. } VkImageConstraintsInfoFlagBitsFUCHSIA;
  111. typedef VkFlags VkImageConstraintsInfoFlagsFUCHSIA;
  112. typedef struct VkBufferCollectionCreateInfoFUCHSIA {
  113. VkStructureType sType;
  114. const void* pNext;
  115. zx_handle_t collectionToken;
  116. } VkBufferCollectionCreateInfoFUCHSIA;
  117. typedef struct VkImportMemoryBufferCollectionFUCHSIA {
  118. VkStructureType sType;
  119. const void* pNext;
  120. VkBufferCollectionFUCHSIA collection;
  121. uint32_t index;
  122. } VkImportMemoryBufferCollectionFUCHSIA;
  123. typedef struct VkBufferCollectionImageCreateInfoFUCHSIA {
  124. VkStructureType sType;
  125. const void* pNext;
  126. VkBufferCollectionFUCHSIA collection;
  127. uint32_t index;
  128. } VkBufferCollectionImageCreateInfoFUCHSIA;
  129. typedef struct VkBufferCollectionConstraintsInfoFUCHSIA {
  130. VkStructureType sType;
  131. const void* pNext;
  132. uint32_t minBufferCount;
  133. uint32_t maxBufferCount;
  134. uint32_t minBufferCountForCamping;
  135. uint32_t minBufferCountForDedicatedSlack;
  136. uint32_t minBufferCountForSharedSlack;
  137. } VkBufferCollectionConstraintsInfoFUCHSIA;
  138. typedef struct VkBufferConstraintsInfoFUCHSIA {
  139. VkStructureType sType;
  140. const void* pNext;
  141. VkBufferCreateInfo createInfo;
  142. VkFormatFeatureFlags requiredFormatFeatures;
  143. VkBufferCollectionConstraintsInfoFUCHSIA bufferCollectionConstraints;
  144. } VkBufferConstraintsInfoFUCHSIA;
  145. typedef struct VkBufferCollectionBufferCreateInfoFUCHSIA {
  146. VkStructureType sType;
  147. const void* pNext;
  148. VkBufferCollectionFUCHSIA collection;
  149. uint32_t index;
  150. } VkBufferCollectionBufferCreateInfoFUCHSIA;
  151. typedef struct VkSysmemColorSpaceFUCHSIA {
  152. VkStructureType sType;
  153. const void* pNext;
  154. uint32_t colorSpace;
  155. } VkSysmemColorSpaceFUCHSIA;
  156. typedef struct VkBufferCollectionPropertiesFUCHSIA {
  157. VkStructureType sType;
  158. void* pNext;
  159. uint32_t memoryTypeBits;
  160. uint32_t bufferCount;
  161. uint32_t createInfoIndex;
  162. uint64_t sysmemPixelFormat;
  163. VkFormatFeatureFlags formatFeatures;
  164. VkSysmemColorSpaceFUCHSIA sysmemColorSpaceIndex;
  165. VkComponentMapping samplerYcbcrConversionComponents;
  166. VkSamplerYcbcrModelConversion suggestedYcbcrModel;
  167. VkSamplerYcbcrRange suggestedYcbcrRange;
  168. VkChromaLocation suggestedXChromaOffset;
  169. VkChromaLocation suggestedYChromaOffset;
  170. } VkBufferCollectionPropertiesFUCHSIA;
  171. typedef struct VkImageFormatConstraintsInfoFUCHSIA {
  172. VkStructureType sType;
  173. const void* pNext;
  174. VkImageCreateInfo imageCreateInfo;
  175. VkFormatFeatureFlags requiredFormatFeatures;
  176. VkImageFormatConstraintsFlagsFUCHSIA flags;
  177. uint64_t sysmemPixelFormat;
  178. uint32_t colorSpaceCount;
  179. const VkSysmemColorSpaceFUCHSIA* pColorSpaces;
  180. } VkImageFormatConstraintsInfoFUCHSIA;
  181. typedef struct VkImageConstraintsInfoFUCHSIA {
  182. VkStructureType sType;
  183. const void* pNext;
  184. uint32_t formatConstraintsCount;
  185. const VkImageFormatConstraintsInfoFUCHSIA* pFormatConstraints;
  186. VkBufferCollectionConstraintsInfoFUCHSIA bufferCollectionConstraints;
  187. VkImageConstraintsInfoFlagsFUCHSIA flags;
  188. } VkImageConstraintsInfoFUCHSIA;
  189. typedef VkResult (VKAPI_PTR *PFN_vkCreateBufferCollectionFUCHSIA)(VkDevice device, const VkBufferCollectionCreateInfoFUCHSIA* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkBufferCollectionFUCHSIA* pCollection);
  190. typedef VkResult (VKAPI_PTR *PFN_vkSetBufferCollectionImageConstraintsFUCHSIA)(VkDevice device, VkBufferCollectionFUCHSIA collection, const VkImageConstraintsInfoFUCHSIA* pImageConstraintsInfo);
  191. typedef VkResult (VKAPI_PTR *PFN_vkSetBufferCollectionBufferConstraintsFUCHSIA)(VkDevice device, VkBufferCollectionFUCHSIA collection, const VkBufferConstraintsInfoFUCHSIA* pBufferConstraintsInfo);
  192. typedef void (VKAPI_PTR *PFN_vkDestroyBufferCollectionFUCHSIA)(VkDevice device, VkBufferCollectionFUCHSIA collection, const VkAllocationCallbacks* pAllocator);
  193. typedef VkResult (VKAPI_PTR *PFN_vkGetBufferCollectionPropertiesFUCHSIA)(VkDevice device, VkBufferCollectionFUCHSIA collection, VkBufferCollectionPropertiesFUCHSIA* pProperties);
  194. #ifndef VK_NO_PROTOTYPES
  195. VKAPI_ATTR VkResult VKAPI_CALL vkCreateBufferCollectionFUCHSIA(
  196. VkDevice device,
  197. const VkBufferCollectionCreateInfoFUCHSIA* pCreateInfo,
  198. const VkAllocationCallbacks* pAllocator,
  199. VkBufferCollectionFUCHSIA* pCollection);
  200. VKAPI_ATTR VkResult VKAPI_CALL vkSetBufferCollectionImageConstraintsFUCHSIA(
  201. VkDevice device,
  202. VkBufferCollectionFUCHSIA collection,
  203. const VkImageConstraintsInfoFUCHSIA* pImageConstraintsInfo);
  204. VKAPI_ATTR VkResult VKAPI_CALL vkSetBufferCollectionBufferConstraintsFUCHSIA(
  205. VkDevice device,
  206. VkBufferCollectionFUCHSIA collection,
  207. const VkBufferConstraintsInfoFUCHSIA* pBufferConstraintsInfo);
  208. VKAPI_ATTR void VKAPI_CALL vkDestroyBufferCollectionFUCHSIA(
  209. VkDevice device,
  210. VkBufferCollectionFUCHSIA collection,
  211. const VkAllocationCallbacks* pAllocator);
  212. VKAPI_ATTR VkResult VKAPI_CALL vkGetBufferCollectionPropertiesFUCHSIA(
  213. VkDevice device,
  214. VkBufferCollectionFUCHSIA collection,
  215. VkBufferCollectionPropertiesFUCHSIA* pProperties);
  216. #endif
  217. #ifdef __cplusplus
  218. }
  219. #endif
  220. #endif