vulkan_fuchsia.h 12 KB

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